这篇文章来自以太中文网:区块链学堂(17):Mist 3–合约页面&部署合约,我会对使用过程中自己遇到的问题进行补充。
Mist 中的合约页面
点击Mist页面中的Contracts,可以看到合约页面
点击按钮 Deploy New Contract 按钮,可以部署一个新的合约,我们点击该按钮, 会看到的上方界面如下:
在From中我们可以选择一个账户,Main Account/account 1, 选择哪个账户,那么那个账户就是该合约的创建者。
那么在构造函数中的msg.sender也就是谁,而同样的变量owner也就是那个账户的地址。
contract Token {
...
address public owner;
function Token() {
owner = msg.sender;
...
}
Amount这里指的是支付给该智能合约的以太币,之前说过,在以太坊中的架构中,智能合约被看作一个特殊的账户,因此智能合约也能和其他账户一样进行交易,可以接受以太币,也可以付出以太币。
这样的特性,在我们的金融化应用中非常有用,例如众筹合约等。
当然目前是一个代币合约,因此这里不需要给智能合约支付任何以太币。
在代码界面,我们贴上下方的代码:
pragma solidity 0.4.8;
contract Token {
mapping (address => uint) public balancesOf;
address public owner;
function Token() {
owner = msg.sender;
balancesOf[msg.sender] = 10000;
}
function transfer(address _to, uint _value) {
if (balancesOf[msg.sender] < _value) throw; //避免转移出去的代币超过当前的存货
if (balancesOf[_to] + _value < balancesOf[_to]) throw; //避免自己调用自己,或者递归调用
balancesOf[msg.sender] -= _value;
balancesOf[_to] += _value;
}
function mint(uint _amount) {
balancesOf[owner] += _amount;
}
}
注:这里右侧编译区会报错:
Source file requires different compiler version (current compiler is 0.4.20+commit.3155dd80.Emscripten.clang - note that nightly builds are considered to be strictly less than the released version
pragma solidity 0.4.8;
从0.4.9起可以在前面不打^ ,0.4.8/0.4.7等版本还是需要打^,这里我们直接使用最新的0.4.20。
No visibility specified. Defaulting to "public".
function Token()
需要指定方法的可见性:public、private、internal、external。
"throw" is deprecated in favour of "revert()", "require()" and "assert()".
if (balancesOf[msg.sender] < _value) throw;
当前编译器版本已经废除了throw,判断使用revert(),,require(),assert()。
下面是修改后的代码:
pragma solidity 0.4.20;
contract Token {
mapping (address => uint) public balancesOf;
address public owner;
function Token() public {
owner = msg.sender;
balancesOf[msg.sender] = 10000;
}
function transfer (address _to, uint _value) public {
require (balancesOf[msg.sender] > _value); //避免转移出去的代币超过当前的存货
require (balancesOf[_to] + _value > balancesOf[_to]); //避免自己调用自己,或者递归调用
balancesOf[msg.sender] -= _value;
balancesOf[_to] += _value;
}
function mint(uint _amount) public {
balancesOf[owner] += _amount;
}
}
所看到的结果如下(图中还是旧代码):
如上图中2所示,只要我们将合约代码贴上去,如果编译通过的话,我们就会看到Mist自动读取出来了我们需要Deploy的合约名称。即Contract Token。
合约的首字母需要为大写,尤其是在多个合约的时候,程序会优先认为首字母为大写的是主合约。
如上图3中所示,我们可以设置合约的部署速度。之前说过合约是一个特殊账户,而任何账户之间的transaction都需要消耗Gas, Gas由合约本身决定,而每百万gas的以太币则由Oracle来决定,价格越贵速度越快优先级越高,价格越便宜速度越慢优先级越低。
消耗Gas就是消耗以太币,因此用任何账户来部署合约,都必须要输入密码。
部署页面解析
点击下方的部署按钮,我们可以看到弹出的这个页面
合约是特殊的账户,deploy合约在以太坊底层就是一个账户到另一个账户的一个Transaction。
Raw Data就是合约代码的编译后的bytecode, 输入密码,并点击Send Transaction 便可完成合约部署。
记得一定要修改下Provide maximum fee 里面的Gas数量。因为一个合约除了部署之外,还需要执行构造函数,并部署数据,Gas不足的话,会导致部署失败。
(注:这里我并没有进行修改,最后也能部署成功。)
部署完毕后的合约页面是这样的
为什么合约没有第一时间出来呢,因为任何合约是一个特殊账户,任何特殊账户之间的Transaction都需要挖矿挖出来,并得到各个区块的确认。
过了一段时间之后,我们可以看到合约出现了。
(注:这里还是需要在Geth中启用挖矿才能部署成功。)
参考:区块链学堂(17):Mist 3–合约页面&部署合约
作者:以太中文网