国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

智能合約語(yǔ)言 Solidity 教程系列10 - 完全理解函數(shù)修改器

Object / 1765人閱讀

摘要:本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接智能合約語(yǔ)言教程系列完全理解函數(shù)修改器原文已更新,請(qǐng)讀者前往原文閱讀這是教程系列文章第篇,帶大家完全理解的函數(shù)修改器。在此上下文中,所有的函數(shù)中引入的符號(hào),在修改器中均可見(jiàn)。

本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)
原文鏈接:智能合約語(yǔ)言 Solidity 教程系列10 - 完全理解函數(shù)修改器原文已更新,請(qǐng)讀者前往原文閱讀

這是Solidity教程系列文章第10篇,帶大家完全理解Solidity的函數(shù)修改器。
Solidity系列完整的文章列表請(qǐng)查看分類-Solidity。

寫在前面

Solidity 是以太坊智能合約編程語(yǔ)言,閱讀本文前,你應(yīng)該對(duì)以太坊、智能合約有所了解,
如果你還不了解,建議你先看以太坊是什么

歡迎訂閱區(qū)塊鏈技術(shù)專欄閱讀更全面的分析文章。

函數(shù)修改器(Function Modifiers)

函數(shù)修改器(Modifiers)可以用來(lái)改變一個(gè)函數(shù)的行為。比如用于在函數(shù)執(zhí)行前檢查某種前置條件。

如果熟悉Python的同學(xué),會(huì)發(fā)現(xiàn)函數(shù)修改器的作用和Python的裝飾器很相似。

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

pragma solidity ^0.4.11;

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

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

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

contract priced {
    // 函數(shù)修改器可接收參數(shù)
    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就是定義的一個(gè)函數(shù)修改器,當(dāng)用這個(gè)修改器區(qū)修飾一個(gè)函數(shù)時(shí),則函數(shù)必須滿足onlyOwner的條件才能運(yùn)行,這里的條件是:必須是合約的創(chuàng)建這才能調(diào)用函數(shù),否則拋出異常。
我們?cè)趯?shí)現(xiàn)一個(gè)可管理、增發(fā)、兌換、凍結(jié)等高級(jí)功能的代幣文章中就使用了這個(gè)函數(shù)修改器。

多個(gè)修改器

如果同一個(gè)函數(shù)有多個(gè)修改器,他們之間以空格隔開(kāi),修飾器會(huì)依次檢查執(zhí)行。

在修改器中或函數(shù)內(nèi)的顯式的return語(yǔ)句,僅僅跳出當(dāng)前的修改器或函數(shù)。返回的變量會(huì)被賦值,但執(zhí)行流會(huì)在前一個(gè)修改器后面定義的"_"后繼續(xù)執(zhí)行, 如:

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

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

修改器的參數(shù)可以是任意表達(dá)式。在此上下文中,所有的函數(shù)中引入的符號(hào),在修改器中均可見(jiàn)。但修改器中引入的符號(hào)在函數(shù)中不可見(jiàn),因?yàn)樗鼈冇锌赡鼙恢貙憽?/p> 深入理解修改器的執(zhí)行次序

再來(lái)看一個(gè)復(fù)雜一點(diǎn)的例子,來(lái)深入理解修改器:

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

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

我們來(lái)分析一下 test1, 它擴(kuò)展之后是這樣的:

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

這個(gè)時(shí)候就一目了然了,最后a 為11, 注意第5及第6行是不是執(zhí)行的。

參考視頻

我們也推出了目前市面上最全的視頻教程:深入詳解以太坊智能合約語(yǔ)言Solidity
目前我們也在招募體驗(yàn)師,可以點(diǎn)擊鏈接了解。

參考文獻(xiàn)

官方文檔-Function Modifiers

? 深入淺出區(qū)塊鏈 - 系統(tǒng)學(xué)習(xí)區(qū)塊鏈,打造最好的區(qū)塊鏈技術(shù)博客。

? 我的知識(shí)星球為各位解答區(qū)塊鏈技術(shù)問(wèn)題,歡迎加入討論。

? 關(guān)注公眾號(hào)“深入淺出區(qū)塊鏈技術(shù)”第一時(shí)間獲取區(qū)塊鏈技術(shù)信息。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/24106.html

相關(guān)文章

  • 區(qū)塊鏈技術(shù)學(xué)習(xí)指引

    摘要:引言給迷失在如何學(xué)習(xí)區(qū)塊鏈技術(shù)的同學(xué)一個(gè)指引,區(qū)塊鏈技術(shù)是隨比特幣誕生,因此要搞明白區(qū)塊鏈技術(shù),應(yīng)該先了解下比特幣。但區(qū)塊鏈技術(shù)不單應(yīng)用于比特幣,還有非常多的現(xiàn)實(shí)應(yīng)用場(chǎng)景,想做區(qū)塊鏈應(yīng)用開(kāi)發(fā),可進(jìn)一步閱讀以太坊系列。 本文始發(fā)于深入淺出區(qū)塊鏈社區(qū), 原文:區(qū)塊鏈技術(shù)學(xué)習(xí)指引 原文已更新,請(qǐng)讀者前往原文閱讀 本章的文章越來(lái)越多,本文是一個(gè)索引帖,方便找到自己感興趣的文章,你也可以使用左側(cè)...

    Cristic 評(píng)論0 收藏0
  • 智能合約語(yǔ)言 Solidity 教程系列9 - 錯(cuò)誤處理

    摘要:本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接智能合約語(yǔ)言教程系列錯(cuò)誤處理原文已更新,請(qǐng)讀者前往原文閱讀這是教程系列文章第篇介紹錯(cuò)誤處理。如果合約沒(méi)有修飾符的的函數(shù)在接收以太幣時(shí)包括構(gòu)造函數(shù),和回退函數(shù)。如果合約通過(guò)一個(gè)的函數(shù)接收以太幣。 本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接:智能合約語(yǔ)言 Solidity 教程系列9 - 錯(cuò)誤處理原文已更新,請(qǐng)讀者前往原文閱讀 這是Solidity教程系列文章...

    xialong 評(píng)論0 收藏0
  • 智能合約語(yǔ)言 Solidity 教程系列4 - 數(shù)據(jù)存儲(chǔ)位置分析

    摘要:狀態(tài)變量合約內(nèi)聲明的公有變量還有一個(gè)存儲(chǔ)位置是,用來(lái)存儲(chǔ)函數(shù)參數(shù),是只讀的,不會(huì)永久存儲(chǔ)的一個(gè)數(shù)據(jù)位置。稱這個(gè)為狀態(tài)改變,這也是合約級(jí)變量稱為狀態(tài)變量的原因。 本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接:智能合約語(yǔ)言 Solidity 教程系列4 - 數(shù)據(jù)存儲(chǔ)位置分析原文已更新,請(qǐng)讀者前往原文閱讀 Solidity教程系列第4篇 - Solidity數(shù)據(jù)位置分析。 寫在前面 Solidity...

    Galence 評(píng)論0 收藏0
  • 智能合約語(yǔ)言 Solidity 教程系列6 - 結(jié)構(gòu)體與映射

    摘要:本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接智能合約語(yǔ)言教程系列結(jié)構(gòu)體與映射原文已更新,請(qǐng)讀者前往原文閱讀教程系列第篇結(jié)構(gòu)體與映射。不能聲明一個(gè)同時(shí)將自身作為成員,這個(gè)限制是基于結(jié)構(gòu)體的大小必須是有限的。 本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接:智能合約語(yǔ)言Solidity教程系列6 - 結(jié)構(gòu)體與映射原文已更新,請(qǐng)讀者前往原文閱讀 Solidity 教程系列第6篇 - Solidity 結(jié)構(gòu)體與...

    masturbator 評(píng)論0 收藏0
  • 智能合約語(yǔ)言Solidity教程系列7 - 以太單位及時(shí)間單位

    摘要:如果想對(duì)輸入的變量說(shuō)明其不同的單位,可以使用下面的方式參考視頻我們也推出了目前市面上最全的視頻教程深入詳解以太坊智能合約語(yǔ)言目前我們也在招募體驗(yàn)師,可以點(diǎn)擊鏈接了解。 本文首發(fā)于深入淺出區(qū)塊鏈社區(qū)原文鏈接:智能合約語(yǔ)言 Solidity 教程系列7 - 以太單位及時(shí)間單位原文已更新,請(qǐng)讀者前往原文閱讀 這是Solidity教程系列文章第7篇介紹以太單位及時(shí)間單位,系列帶你全面深入理解S...

    justCoding 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

Object

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<