摘要:本文首發于深入淺出區塊鏈社區原文鏈接智能合約語言教程系列函數類型原文已更新,請讀者前往原文閱讀教程系列第三篇函數類型介紹。函數類型函數也是一種類型,且屬于值類型。但以此相反,合約中函數本身默認是的,僅僅是當作類型名使用時默認是的。
本文首發于深入淺出區塊鏈社區
原文鏈接:智能合約語言Solidity教程系列3 - 函數類型原文已更新,請讀者前往原文閱讀
Solidity 教程系列第三篇 - Solidity 函數類型介紹。
Solidity 系列完整的文章列表請查看分類-Solidity。
Solidity 是以太坊智能合約編程語言,閱讀本文前,你應該對以太坊、智能合約有所了解,如果你還不了解,建議你先看以太坊是什么
本文前半部分是參考Solidity 官方文檔(當前最新版本:0.4.20)進行翻譯,后半部分函數可見性( public, external, internal, privite )深度分析(僅針對專欄訂閱用戶)。
函數類型(Function Types)函數也是一種類型,且屬于值類型。
可以將一個函數賦值給一個函數類型的變量。還可以將一個函數作為參數進行傳遞。也可以在函數調用中返回一個函數。
函數類型有兩類:內部(internal)和外部(external)函數
內部(internal)函數只能在當前合約內被調用(在當前的代碼塊內,包括內部庫函數,和繼承的函數中)。
外部(external)函數由地址和函數方法簽名兩部分組成,可作為外部函數調用的參數,或返回值。
函數類型定義如下:
function () {internal|external} [pure|constant|view|payable] [returns ( )]
如果函數不需要返回,則省去returns (
函數類型默認是internal, 因此internal可以省去。但以此相反,合約中函數本身默認是public的, 僅僅是當作類型名使用時默認是internal的。
有兩個方式訪問函數,一種是直接用函數名f, 一種是this.f, 前者用于內部函數,后者用于外部函數。
如果一個函數變量沒有初始化,直接調用它將會產生異常。如果delete了一個函數后調用,也會發生同樣的異常。
如果外部函數類型在Solidity的上下文環境以外的地方使用,他們會被視為function類型。它會編碼為20字節的函數所在地址,和在它之前的4字節的函數方法簽名一起作為bytes24類型。
合約中的public的函數,可以使用internal和external兩種方式來調用。
internal訪問形式為f, external訪問形式為this.f
public (或 external) 函數有一個特殊的成員selector, 它對應一個ABI 函數選擇器。
pragma solidity ^0.4.16; contract Selector { function f() public view returns (bytes4) { return this.f.selector; } }
下面的代碼顯示內部(internal)函數類型的使用:
pragma solidity ^0.4.16; library ArrayUtils { // internal functions can be used in internal library functions because // they will be part of the same code context function map(uint[] memory self, function (uint) pure returns (uint) f) internal pure returns (uint[] memory r) { r = new uint[](self.length); for (uint i = 0; i < self.length; i++) { r[i] = f(self[i]); } } function reduce( uint[] memory self, function (uint, uint) pure returns (uint) f ) internal pure returns (uint r) { r = self[0]; for (uint i = 1; i < self.length; i++) { r = f(r, self[i]); } } function range(uint length) internal pure returns (uint[] memory r) { r = new uint[](length); for (uint i = 0; i < r.length; i++) { r[i] = i; } } } contract Pyramid { using ArrayUtils for *; function pyramid(uint l) public pure returns (uint) { return ArrayUtils.range(l).map(square).reduce(sum); } function square(uint x) internal pure returns (uint) { return x * x; } function sum(uint x, uint y) internal pure returns (uint) { return x + y; } }
下面的代碼顯示外部(external)函數類型的使用:
pragma solidity ^0.4.11; contract Oracle { struct Request { bytes data; function(bytes memory) external callback; } Request[] requests; event NewRequest(uint); function query(bytes data, function(bytes memory) external callback) public { requests.push(Request(data, callback)); NewRequest(requests.length - 1); } function reply(uint requestID, bytes response) public { // Here goes the check that the reply comes from a trusted source requests[requestID].callback(response); } } contract OracleUser { Oracle constant oracle = Oracle(0x1234567); // known contract function buySomething() { oracle.query("USD", this.oracleResponse); } function oracleResponse(bytes response) public { require(msg.sender == address(oracle)); // Use the data } }函數可見性分析
public - 任意訪問
private - 僅當前合約內
internal - 僅當前合約及所繼承的合約
external - 僅外部訪問(在內部也只能用外部訪問方式訪問)
public 還是 external 最佳實踐請訂閱區塊鏈技術查看。
參考視頻我們也推出了目前市面上最全的視頻教程:深入詳解以太坊智能合約語言Solidity
目前我們也在招募體驗師,可以點擊鏈接了解。
Solidity官方文檔-類型
? 深入淺出區塊鏈 - 系統學習區塊鏈,打造最好的區塊鏈技術博客。
? 我的知識星球為各位解答區塊鏈技術問題,歡迎加入討論。
? 關注公眾號“深入淺出區塊鏈技術”第一時間獲取區塊鏈技術信息。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/24113.html
摘要:本文首發于深入淺出區塊鏈社區原文鏈接智能合約語言教程系列錯誤處理原文已更新,請讀者前往原文閱讀這是教程系列文章第篇介紹錯誤處理。如果合約沒有修飾符的的函數在接收以太幣時包括構造函數,和回退函數。如果合約通過一個的函數接收以太幣。 本文首發于深入淺出區塊鏈社區原文鏈接:智能合約語言 Solidity 教程系列9 - 錯誤處理原文已更新,請讀者前往原文閱讀 這是Solidity教程系列文章...
摘要:狀態變量合約內聲明的公有變量還有一個存儲位置是,用來存儲函數參數,是只讀的,不會永久存儲的一個數據位置。稱這個為狀態改變,這也是合約級變量稱為狀態變量的原因。 本文首發于深入淺出區塊鏈社區原文鏈接:智能合約語言 Solidity 教程系列4 - 數據存儲位置分析原文已更新,請讀者前往原文閱讀 Solidity教程系列第4篇 - Solidity數據位置分析。 寫在前面 Solidity...
摘要:地址類型的成員屬性及函數這里是地址類型相關成員的快速索引用來查詢賬戶余額,用來發送以太幣以為單位。因此,為了保證安全,必須檢查的返回值,如果交易失敗,會回退以太幣。 本文首發于深入淺出區塊鏈社區原文鏈接:智能合約語言 Solidity 教程系列2 - 地址類型介紹原文已更新,請讀者前往原文閱讀 Solidity教程系列第二篇 - Solidity地址類型介紹. Solidity 系列完...
摘要:還需注意的一點是,定長數組,不能與變長數組相互賦值,我們來看下面的代碼無法編譯已經計劃在未來移除這樣的限制。的變長數組,可以通過給賦值調整數組長度。的變長數組不支持。 本文首發于深入淺出區塊鏈社區原文鏈接:智能合約語言Solidity教程系列5 - 數組介紹原文已更新,請讀者前往原文閱讀 Solidity 教程系列第5篇 - Solidity 數組介紹。Solidity 系列完整的文章...
閱讀 3090·2021-11-22 13:54
閱讀 842·2021-11-04 16:08
閱讀 4540·2021-10-11 11:09
閱讀 3605·2021-09-22 16:05
閱讀 936·2019-08-30 15:54
閱讀 397·2019-08-30 15:44
閱讀 603·2019-08-30 14:05
閱讀 1025·2019-08-30 12:46