以太坊开发(九)Mist使用:合约及部署合约

这篇文章来自以太中文网:区块链学堂(17):Mist 3–合约页面&部署合约,我会对使用过程中自己遇到的问题进行补充。

Mist 中的合约页面

点击Mist页面中的Contracts,可以看到合约页面

以太坊开发(九)Mist使用:合约及部署合约_第1张图片

点击按钮 Deploy New Contract 按钮,可以部署一个新的合约,我们点击该按钮, 会看到的上方界面如下:

以太坊开发(九)Mist使用:合约及部署合约_第2张图片

在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;
  }
}

所看到的结果如下(图中还是旧代码):

以太坊开发(九)Mist使用:合约及部署合约_第3张图片
  • 如上图中2所示,只要我们将合约代码贴上去,如果编译通过的话,我们就会看到Mist自动读取出来了我们需要Deploy的合约名称。即Contract Token。

  • 合约的首字母需要为大写,尤其是在多个合约的时候,程序会优先认为首字母为大写的是主合约。

  • 如上图3中所示,我们可以设置合约的部署速度。之前说过合约是一个特殊账户,而任何账户之间的transaction都需要消耗Gas, Gas由合约本身决定,而每百万gas的以太币则由Oracle来决定,价格越贵速度越快优先级越高,价格越便宜速度越慢优先级越低。

  • 消耗Gas就是消耗以太币,因此用任何账户来部署合约,都必须要输入密码。

部署页面解析

点击下方的部署按钮,我们可以看到弹出的这个页面

以太坊开发(九)Mist使用:合约及部署合约_第4张图片
  • 合约是特殊的账户,deploy合约在以太坊底层就是一个账户到另一个账户的一个Transaction。

  • Raw Data就是合约代码的编译后的bytecode, 输入密码,并点击Send Transaction 便可完成合约部署。

  • 记得一定要修改下Provide maximum fee 里面的Gas数量。因为一个合约除了部署之外,还需要执行构造函数,并部署数据,Gas不足的话,会导致部署失败。

以太坊开发(九)Mist使用:合约及部署合约_第5张图片

(注:这里我并没有进行修改,最后也能部署成功。)

部署完毕后的合约页面是这样的

以太坊开发(九)Mist使用:合约及部署合约_第6张图片

为什么合约没有第一时间出来呢,因为任何合约是一个特殊账户,任何特殊账户之间的Transaction都需要挖矿挖出来,并得到各个区块的确认。

过了一段时间之后,我们可以看到合约出现了。

以太坊开发(九)Mist使用:合约及部署合约_第7张图片

(注:这里还是需要在Geth中启用挖矿才能部署成功。)

参考:区块链学堂(17):Mist 3–合约页面&部署合约
作者:以太中文网

你可能感兴趣的:(以太坊开发(九)Mist使用:合约及部署合约)