热搜:
405 0 0
  • tv48
    • 34
      帖子
    • 0
      评论
    • 723
      源点
    以太坊智能合约生命周期(Ethereum smart contracts lifecycle)
    发表于2个月前 只看楼主 帖子标签:

    合约对象初始化


    上一节中我们提到Solidity编写合约和面向对象编程语言非常相似,我们可以通过构造函数(constructor)来初始化合约对象。构造函数就是方法名和合约名字相同的函数,创建合约时会调用构造函数对状态变量进行数据初始化操作。



    pragma solidity ^0.4.4;



    contract Power {



    uint value; /* 合约初始化时会调用构造函数 */
    function Power(uint number, uint p) {
    value = number ** p;
    }



    function getPower() constant returns (uint) {
    return value;
    }



    }

    同一个合约是否运行有两个构造函数?

    由上图不难看出,当我们同一个合约如果有多个构造函数时,会出现下面的错误提示:

    More than one constructor defined.
    function Power(uint number) {
    ^
    Spanning multiple lines.
    Another declaration is here
    如果你尝试部署Power合约,你将看到需要提供两个参数进行合约交易。

    合约部署成功后,我们将会看到getPower函数返回的值。

    构造函数(constructor)会在合约创建时对数据进行初始化,传统的类会在对象销毁时调用析构函数(destructor),在以太坊智能合约中,同样在合约销毁时,自动调用析构函数销毁相关数据。

    合约地址


    在传统的面向对象编程中,每一个已经创建的对象都会有一个存储这个对象的地址,我们一般通过这个地址或者指向这个地址的指针对其进行操作,在以太坊智能合约开发中,当一个合约部署时,同样会生成一个合约地址(address),我们后续可以直接通过这个合约地址(address)对这个合约进行交互操作。如果你想知道当前和也的合约地址,你可以通过msg.sender获取。

    让我们来对我们上一篇中的Counter合约进行改进,合约对象创建时在构造函数中保存我们当前合约的合约地址,在increment函数中增加一个判断,只有当在我们合约内部调用时,状态变量count才加1,否则不做任何其他操作。

    pragma solidity ^0.4.4;

    contract Counter {

    uint count = 0;
    address owner; //存储Counter合约地址

    function Counter() {
    owner = msg.sender; // 存储Counter合约地址
    }

    function increment() public {
    if (owner == msg.sender) { // 判断是谁在调用`increment`方法
    count = count + 1;
    }
    }
    /* 读取count的值 */
    function getCount() constant returns (uint) {
    return count;
    }

    }
    因此我们给合约增加了一层保护层,只有创建合约的creator才能够自己调用increment方法让count加1。

    析构函数 - 一个合约的销毁


    最完美的事情是有开始有结尾,合约也一样,它也可以结束。当一个合约通过kill方法将其杀死,那么我们将不能再和这个合约进行交互,如果一个合约被销毁,那么当前地址指向的是一个僵尸对象,这个僵尸对象调用任何方法都会抛出异常。你想销毁合约,需要调用selfdestruct(address)才能将其进行销毁。

    pragma solidity ^0.4.4;

    contract Counter {

    uint count = 0;
    address owner;
    function Counter() {
    owner = msg.sender;
    }

    function increment() public {
    if (owner == msg.sender) {
    count = count + 1;
    }
    }
    function getCount() constant returns (uint) {
    return count;
    }

    function kill() {
    if (owner == msg.sender) { // 检查谁在调用
    selfdestruct(owner); // 销毁合约
    }
    }

    }
    在其他一些比较老的教程里面,你可能会看到suicide()方法,但是为了语言更好的可读性,这个方法目前已经重新命名,以后如有需要,大家直接调用selfdestruct()方法就好。

    接下来让我们调用我们的kill方法查看效果:

    执行kill方法,过一会儿刷新,你会发现刚才的合约已经没了。


    小结


    本节中,我们学习了一个简单但是完整的合约,详细讲解了合约的构造函数、析构函数,以及如何部署到区块链,当我们调用kill方法时,会调用析构函数将合约销毁的整个过程。

    文章来源:公众号-区块链部落

添加评论 (需要登录)