亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Solidity函數修改器怎么使用

發布時間:2021-12-07 15:41:03 來源:億速云 閱讀:118 作者:iii 欄目:互聯網科技

這篇文章主要講解了“Solidity函數修改器怎么使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Solidity函數修改器怎么使用”吧!

函數修改器(Function Modifiers)

函數修改器(Modifiers)可以用來改變一個函數的行為。比如用于在函數執行前檢查某種前置條件。

如果熟悉Python的同學,會發現函數修改器的作用和Python的裝飾器很相似。

修改器是一種可被繼承合約屬性,同時還可被繼承的合約重寫(override)。下面我們來看一段示例代碼:

pragma solidity ^0.4.11;

contract owned {
    function owned() public { owner = msg.sender; }
    address owner;

    // 定義了一個函數修改器,可被繼承
    //  修飾時,函數體被插入到 “_;” 處
    // 不符合條件時,將拋出異常
    modifier onlyOwner {
        require(msg.sender == owner);
        _;
    }
}

contract mortal is owned {
    //  使用繼承的`onlyOwner` 
    function close() public onlyOwner {
        selfdestruct(owner);
    }
}

contract priced {
    // 函數修改器可接收參數
    modifier costs(uint price) {
        if (msg.value >= price) {
            _;
        }
    }
}

contract Register is priced, owned {
    mapping (address => bool) registeredAddresses;
    uint price;

    function Register(uint initialPrice) public { price = initialPrice; }

    // 需要提供payable 以接受以太
    function register() public payable costs(price) {
        registeredAddresses[msg.sender] = true;
    }

    function changePrice(uint _price) public onlyOwner {
        price = _price;
    }
}

上面onlyOwner就是定義的一個函數修改器,當用這個修改器區修飾一個函數時,則函數必須滿足onlyOwner的條件才能運行,這里的條件是:必須是合約的創建這才能調用函數,否則拋出異常。 我們在實現一個可管理、增發、兌換、凍結等高級功能的代幣文章中就使用了這個函數修改器。

多個修改器

如果同一個函數有多個修改器,他們之間以空格隔開,修飾器會依次檢查執行。

在修改器中或函數內的顯式的return語句,僅僅跳出當前的修改器或函數。返回的變量會被賦值,但執行流會在前一個修改器后面定義的"_"后繼續執行, 如:

contract Mutex {
    bool locked;
    modifier noReentrancy() {
        require(!locked);
        locked = true;
        _;
        locked = false;
    }

    // 防止遞歸調用
    // return 7 之后,locked = false 依然會執行
    function f() public noReentrancy returns (uint) {
        require(msg.sender.call());
        return 7;
    }
}

修改器的參數可以是任意表達式。在此上下文中,所有的函數中引入的符號,在修改器中均可見。但修改器中引入的符號在函數中不可見,因為它們有可能被重寫。

深入理解修改器的執行次序

再來看一個復雜一點的例子,來深入理解修改器:

pragma solidity ^0.4.11;


contract modifysample {

    uint a = 10;
    
    modifier mf1 (uint b) {
        uint c = b;
        _;
        c = a;
        a = 11;
    }
    
     modifier mf2 () {
        uint c = a;
        _;
    }
    
    modifier mf3() {
        a = 12;
        return ;
        _;
        a = 13;
    }
    
    function test1() mf1(a) mf2 mf3 public   {
        a = 1;
    }
    
     function test2() public constant returns (uint)   {
        return a;  
    }  
}

上面的智能合約運行test1()之后,狀態變量a的值是多少, 是1, 11, 12,還是13呢? 答案是 11, 大家可以運行下test2獲取下a值。

我們來分析一下 test1, 它擴展之后是這樣的:

uint c = b;
        uint c = a;
            a = 12;
            return ;
            _;
            a = 13;
c = a;
a = 11;

這個時候就一目了然了,最后a 為11, 注意第5及第6行是不是執行的。

感謝各位的閱讀,以上就是“Solidity函數修改器怎么使用”的內容了,經過本文的學習后,相信大家對Solidity函數修改器怎么使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西乌| 敖汉旗| 封丘县| 江北区| 磴口县| 巩留县| 大渡口区| 连江县| 伊金霍洛旗| 平安县| 元谋县| 江油市| 玛曲县| 滕州市| 辽阳县| 江孜县| 鄂托克旗| 屏山县| 丰宁| 厦门市| 曲麻莱县| 贵港市| 临西县| 开封县| 怀化市| 冷水江市| 当涂县| 米易县| 汾西县| 闻喜县| 呼和浩特市| 门头沟区| 铜陵市| 蒙自县| 莱西市| 梓潼县| 合川市| 威远县| 应城市| 富源县| 洞头县|