以太坊智能合约生命周期(Ethereum smart contracts lifecycle)

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

作者:黎跃春,区块链、高可用架构工程师

原文链接:http://blog.csdn.net/liyuechun520/article/details/78408564

著权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文约2100字+,阅读(观看)需要13分钟


合约对象初始化


上一节中我们提到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),在以太坊智能合约中,同样在合约销毁时,自动调用析构函数销毁相关数据。


合约owner


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


pragma solidity ^0.4.4;

contract Counter {

   uint count = 0;

   address owner; //存储Counter合约owner function Counter() { owner = msg.sender; // 存储Counter合约owner } 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方法时,会调用析构函数将合约销毁的整个过程。


文章发布只为分享区块链技术内容,版权归原作者所有,观点仅代表作者本人,绝不代表区块链兄弟赞同其观点或证实其描述。

attachments-2018-02-VbOClZC05a7fafcbcc448.jpg


  • 发表于 2018-03-01 11:52
  • 阅读 ( 3795 )
  • 分类:以太坊

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
不写代码的码农
社区运营-小以

430 篇文章

作家榜 »

  1. 社区运营-小以 430 文章
  2. 社区运营-小链 244 文章
  3. 于中阳Mercina-zy 78 文章
  4. 涂晶 71 文章
  5. 李晓琼 45 文章
  6. 兄弟连区块链培训 41 文章
  7. 吴寿鹤 36 文章
  8. John-smith 26 文章