這篇文章主要介紹“Solidity智能合約怎么實現(xiàn)”,在日常操作中,相信很多人在Solidity智能合約怎么實現(xiàn)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Solidity智能合約怎么實現(xiàn)”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
創(chuàng)新互聯(lián)建站專注于企業(yè)全網(wǎng)整合營銷推廣、網(wǎng)站重做改版、仁壽網(wǎng)站定制設計、自適應品牌網(wǎng)站建設、html5、商城網(wǎng)站定制開發(fā)、集團公司官網(wǎng)建設、外貿(mào)網(wǎng)站建設、高端網(wǎng)站制作、響應式網(wǎng)頁設計等建站業(yè)務,價格優(yōu)惠性價比高,為仁壽等各大城市提供網(wǎng)站開發(fā)制作服務。
比特幣是第一個真正意義上的區(qū)塊鏈,不過,從嚴格意義上來講,它對智能合約的開發(fā)者是不友好的。
可以用一種低門檻的編程語言Bitcoin Script在比特幣系統(tǒng)上編寫智能合約。每個比特幣地址都對應著一個Bitcoin Script程序??雌饋硎沁@樣:
IF 23 CHECKMULTISIG ELSE "30d" CHECKSEQUENCEVERIFY DROP CHECKSIG ENDIF
另一種較高級別的語言是Ivy,它可以編譯成Bitcoin Script。Ivy能夠幫助你編寫自定義的比特幣地址,這種地址與隔離見證(SegWit)兼容,在比特幣協(xié)議(包括簽名檢查、hash特征值(commitment)和時間鎖)的支持下,可以執(zhí)行任意條件組合。例如:
contract EscrowWithDeplay{ sender: PublicKey recipient: PublicKey, escrow: PublicKey, delay: Duration, val: Value }{ clause transfer(sig1: Signature, sig2: Signature){ verify checkMultiSig([sender, recipient, escrow],[sig1, sig2]) unlock val } clause timeout(sig: Signature){ verify checkSig(sender, sig) verify older(delay) unlock val } }
比特幣“虛擬機”——協(xié)議中負責執(zhí)行Bitcoin Script程序的一部分——與以太坊或者Chain Protocol等其它智能合約平臺的虛擬機相比(功能)更加有限,其指令系統(tǒng)甚至不是圖靈完備的。但Bitcoin Script的確提供了一組很有用的基礎原語(primitives)——簽名校驗、哈希計算以及相對和絕對的時間鎖——另外還能對這些原語進行自由組合。
fabric是超級賬本大家庭中最成熟的一個區(qū)塊鏈項目,主要用于行業(yè)鏈、聯(lián)盟聯(lián)或私有鏈,它不需要通過挖礦來形成共識,因此可以達到很高的交易速度。
在fabric中,智能合約被稱為鏈碼(Chaincode),實質上是控制區(qū)塊鏈網(wǎng)絡中的不同實體或相關方如何相互交互或交易的業(yè)務邏輯。簡言之,鏈代碼將業(yè)務網(wǎng)絡交易封裝在代碼中??梢哉{(diào)用鏈代碼來設置和獲取賬本或 world state。
超級賬本可以使用go、java或者nodejs來開發(fā)智能合約,不過支持最好的還是go語言。下面是使用go開發(fā)的一個簡單地fabric智能合約:
package main import "fmt" import "github.com/hyperledger/fabric/core/chaincode/shim" type SampleChaincode struct { } func (t *SampleChaincode) Init(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) { return nil, nil } func (t *SampleChaincode) Query(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) { return nil, nil } func (t *SampleChaincode) Invoke(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) { return nil, nil } func main() { err := shim.Start(new(SampleChaincode)) if err != nil { fmt.Println("Could not start SampleChaincode") } else { fmt.Println("SampleChaincode successfully started") } }
frabric的智能合約可以使用一個go中的類實現(xiàn),它必須要實現(xiàn)約定的借口Init和Query。
Init 方法 在鏈代碼首次部署到區(qū)塊鏈網(wǎng)絡時調(diào)用,將由部署自己的鏈代碼實例的每個對等節(jié)點執(zhí)行。而只要在區(qū)塊鏈狀態(tài)上執(zhí)行任何讀取/獲取/查詢操作,就會調(diào)用 Query 方法。
訪問這里了解更多關于fabric的智能合約開發(fā)的相關信息:Fabric Chaincode
以太坊是第一個提供完善的智能合約開發(fā)框架的區(qū)塊鏈,因此它也被稱為區(qū)塊鏈2.0的代表。事實上,目前絕大多數(shù)的區(qū)塊鏈應用,包括ICO代幣發(fā)行,都是基于以太坊來實現(xiàn)的智能合約應用。
以太坊有四種專用語言可以用來開發(fā)智能合約:
Solidity ,受JavaScript 啟發(fā)
Serpent ,受Python啟發(fā)
Mutan,受Go 啟發(fā)
LLL 受Lisp 啟發(fā)
這四種語言都是為面向合約編程而從底層開始設計的語言,但從目前的發(fā)展來看,Solidity已經(jīng)稱為以太坊智能合約開發(fā)當之無愧的首選語言。
Solidity的語法類似于JavaScript,這降低了學習門檻,易于被掌握和使用,因為JavaScript是Web開發(fā)者的常用語言。例如,下面是一個使用Solidity開發(fā)的簡單但完整的智能合約:
pragma solidity ^0.4.21; contract HelloWorld { string hello = "Hello World!!!"; event say(string _value); function sayHello() public { emit say(hello); } }
合約代碼第一行指定該合約使用的Solidity版本為0.4.21,不支持高于0.4.21版本的Solidity特性。
在Solidity中,contract關鍵字包含的代碼段即表示一個智能合約,它擁有一些成員變量和函數(shù),看起來非常類似于傳統(tǒng)的面向對象開發(fā)中的類。
到此,關于“Solidity智能合約怎么實現(xiàn)”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
網(wǎng)站標題:Solidity智能合約怎么實現(xiàn)
文章來源:http://weahome.cn/article/pgcopo.html