美文网首页以太坊以太坊区块链开发区块链研究
修饰符让Solidity开发以太坊智能合约有更好可读性

修饰符让Solidity开发以太坊智能合约有更好可读性

作者: 编程狂魔 | 来源:发表于2018-11-08 09:16 被阅读1次

修饰符是可以应用于其他函数的一个函数。在调用函数之前,确保满足某些先决条件非常有用。我们举一个简单的例子,在我们已经写过的合约中,我们经常要检查函数的调用者是否是合约的所有者:

    function increment() public {
       if (owner == msg.sender) { // We check who calls the function
          count = count + 1;
       }
    }

想象一下,如果我们的智能合约有多个只能由所有者调用的函数,那么如果owner == msg.sender部分需要重构那么怎么做?这是修饰语将帮助我们的地方。让我们看第一个修饰符:

    modifier isAdmin() {
        require(msg.sender == owner);
        _;
    }
 
    function increment() public isAdmin {
        count = count + 1;
    }

我们的修饰符看起来像一个函数。require()函数评估条件,如果不满足条件将抛出异常,这将停止执行我们的智能合约。_关键字告诉编译器用函数体替换_

与函数一样,修饰符可以接受参数。假设我们可以拥有多个用户,并希望检查所有权,看下面的代码:

    modifier onlyBy(address _account) {
        require(msg.sender == _account);
        _;
    }
 
    function increment() public onlyBy(owner) {
        count = count + 1;
    }

正如你所看到的,我们的修饰符更通用,这让我们可以做更多事。

你还可以编写最通用的修饰符,只有在任何条件为真时才运行:

    modifier onlyIf(bool _condition) {
        require(_condition);
        _;
    }
 
    function increment() public onlyIf(msg.sender == owner) {
        count = count + 1;

通过在空格分隔的列表中指定多个修饰符,将多个修饰符应用于函数,并按所显示的顺序进行评估。

    modifier onlyIf(bool _condition) {
        require(_condition);
        _;
    }
 
    function increment() public onlyIf(msg.sender == owner) onlyIf(count < 200) {
        count = count + 1;
    }

在下一个教程中,我们将学习如何使用一个智能合约来创建其他智能合约并与之交互,用工厂模式管理多个solidity智能合约

======================================================================

分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:

  • java以太坊开发教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。
  • python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
  • php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。
  • 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
  • 以太坊开发进阶教程,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
  • C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
  • EOS教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
  • java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
  • php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
  • tendermint区块链开发详解,本课程适合希望使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是go语言工程师快速入门区块链开发的最佳选择。

汇智网原创翻译,转载请标明出处。这里是原文使用修饰符让Solidity开发有更好的可读性

相关文章

网友评论

    本文标题:修饰符让Solidity开发以太坊智能合约有更好可读性

    本文链接:https://www.haomeiwen.com/subject/ptyixqtx.html