欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

以太坊可以用go語言,以太坊 go語言

Go語言的應(yīng)用

Go語言由Google公司開發(fā),并于2009年開源,相比Java/Python/C等語言,Go尤其擅長并發(fā)編程,性能堪比C語言,開發(fā)效率肩比Python,被譽(yù)為“21世紀(jì)的C語言”。

成都網(wǎng)絡(luò)公司-成都網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)建站十余年經(jīng)驗(yàn)成就非凡,專業(yè)從事成都網(wǎng)站建設(shè)、網(wǎng)站制作,成都網(wǎng)頁設(shè)計(jì),成都網(wǎng)頁制作,軟文發(fā)布平臺(tái)廣告投放等。十余年來已成功提供全面的成都網(wǎng)站建設(shè)方案,打造行業(yè)特色的成都網(wǎng)站建設(shè)案例,建站熱線:13518219792,我們期待您的來電!

Go語言在云計(jì)算、大數(shù)據(jù)、微服務(wù)、高并發(fā)領(lǐng)域應(yīng)用應(yīng)用非常廣泛。BAT大廠正在把Go作為新項(xiàng)目開發(fā)的首選語言。

Go語言應(yīng)用范圍:

1、服務(wù)端開發(fā):以前你使用C或者C++做的那些事情,用Go來做很合適,例如日志處理、文件系統(tǒng)、監(jiān)控系統(tǒng)等;

2、DevOps:運(yùn)維生態(tài)中的Docker、K8s、prometheus、grafana、open-falcon等都是使用Go語言開發(fā);

3、網(wǎng)絡(luò)編程:大量優(yōu)秀的Web框架如Echo、Gin、Iris、beego等,而且Go內(nèi)置的 net/http包十分的優(yōu)秀;

4、Paas云平臺(tái)領(lǐng)域:Kubernetes和Docker Swarm等;

5、分布式存儲(chǔ)領(lǐng)域:etcd、Groupcache、TiDB、Cockroachdb、Influxdb等;

6、區(qū)塊鏈領(lǐng)域:區(qū)塊鏈里面有兩個(gè)明星項(xiàng)目以太坊和fabric都使用Go語言;

7、容器虛擬化:大名鼎鼎的Docker就是使用Go語言實(shí)現(xiàn)的;

8、爬蟲及大數(shù)據(jù):Go語言天生支持并發(fā),所以十分適合編寫分布式爬蟲及大數(shù)據(jù)處理。

一學(xué)就會(huì),手把手教你用Go語言調(diào)用智能合約

智能合約調(diào)用是實(shí)現(xiàn)一個(gè) DApp 的關(guān)鍵,一個(gè)完整的 DApp 包括前端、后端、智能合約及區(qū)塊 鏈系統(tǒng),智能合約的調(diào)用是連接區(qū)塊鏈與前后端的關(guān)鍵。

我們先來了解一下智能合約調(diào)用的基礎(chǔ)原理。智能合約運(yùn)行在以太坊節(jié)點(diǎn)的 EVM 中。因此要 想調(diào)用合約必須要訪問某個(gè)節(jié)點(diǎn)。

以后端程序?yàn)槔蠖朔?wù)若想連接節(jié)點(diǎn)有兩種可能,一種是雙 方在同一主機(jī),此時(shí)后端連接節(jié)點(diǎn)可以采用 本地 IPC(Inter-Process Communication,進(jìn) 程間通信)機(jī)制,也可以采用 RPC(Remote Procedure Call,遠(yuǎn)程過程調(diào)用)機(jī)制;另 一種情況是雙方不在同一臺(tái)主機(jī),此時(shí)只能采用 RPC 機(jī)制進(jìn)行通信。

提到 RPC, 讀者應(yīng)該對(duì) Geth 啟動(dòng)參數(shù)有點(diǎn)印象,Geth 啟動(dòng)時(shí)可以選擇開啟 RPC 服務(wù),對(duì)應(yīng)的 默認(rèn)服務(wù)端口是 8545。。

接著,我們來了解一下智能合約運(yùn)行的過程。

智能合約的運(yùn)行過程是后端服務(wù)連接某節(jié)點(diǎn),將 智能合約的調(diào)用(交易)發(fā)送給節(jié)點(diǎn),節(jié)點(diǎn)在驗(yàn)證了交易的合法性后進(jìn)行全網(wǎng)廣播,被礦工打包到 區(qū)塊中代表此交易得到確認(rèn),至此交易才算完成。

就像數(shù)據(jù)庫一樣,每個(gè)區(qū)塊鏈平臺(tái)都會(huì)提供主流 開發(fā)語言的 SDK(Software Development Kit,軟件開發(fā)工具包),由于 Geth 本身就是用 Go 語言 編寫的,因此若想使用 Go 語言連接節(jié)點(diǎn)、發(fā)交易,直接在工程內(nèi)導(dǎo)入 go-ethereum(Geth 源碼) 包就可以了,剩下的問題就是流程和 API 的事情了。

總結(jié)一下,智能合約被調(diào)用的兩個(gè)關(guān)鍵點(diǎn)是節(jié)點(diǎn)和 SDK。

由于 IPC 要求后端與節(jié)點(diǎn)必須在同一主機(jī),所以很多時(shí)候開發(fā)者都會(huì)采用 RPC 模式。除了 RPC,以太坊也為開發(fā)者提供了 json- rpc 接口,本文就不展開討論了。

接下來介紹如何使用 Go 語言,借助 go-ethereum 源碼庫來實(shí)現(xiàn)智能合約的調(diào)用。這是有固定 步驟的,我們先來說一下總體步驟,以下面的合約為例。

步驟 01:編譯合約,獲取合約 ABI(Application Binary Interface,應(yīng)用二進(jìn)制接口)。 單擊【ABI】按鈕拷貝合約 ABI 信息,將其粘貼到文件 calldemo.abi 中(可使用 Go 語言IDE 創(chuàng)建該文件,文件名可自定義,后綴最好使用 abi)。

最好能將 calldemo.abi 單獨(dú)保存在一個(gè)目錄下,輸入“l(fā)s”命令只能看到 calldemo.abi 文件,參 考效果如下:

步驟 02:獲得合約地址。注意要將合約部署到 Geth 節(jié)點(diǎn)。因此 Environment 選擇為 Web3 Provider。

在【Environment】選項(xiàng)框中選擇“Web3 Provider”,然后單擊【Deploy】按鈕。

部署后,獲得合約地址為:0xa09209c28AEf59a4653b905792a9a910E78E7407。

步驟 03:利用 abigen 工具(Geth 工具包內(nèi)的可執(zhí)行程序)編譯智能合約為 Go 代碼。abigen 工具的作用是將 abi 文件轉(zhuǎn)換為 Go 代碼,命令如下:

其中各參數(shù)的含義如下。 (1)abi:是指定傳入的 abi 文件。 (2)type:是指定輸出文件中的基本結(jié)構(gòu)類型。 (3)pkg:指定輸出文件 package 名稱。 (4)out:指定輸出文件名。 執(zhí)行后,將在代碼目錄下看到 funcdemo.go 文件,讀者可以打開該文件欣賞一下,注意不要修改它。

步驟 04:創(chuàng)建 main.go,填入如下代碼。 注意代碼中 HexToAddress 函數(shù)內(nèi)要傳入該合約部署后的地址,此地址在步驟 01 中獲得。

步驟 04:設(shè)置 go mod,以便工程自動(dòng)識(shí)別。

前面有所提及,若要使用 Go 語言調(diào)用智能合約,需要下載 go-ethereum 工程,可以使用下面 的指令:

該指令會(huì)自動(dòng)將 go-ethereum 下載到“$GOPATH/src/github.com/ethereum/go-ethereum”,這樣還算 不錯(cuò)。不過,Go 語言自 1.11 版本后,增加了 module 管理工程的模式。只要設(shè)置好了 go mod,下載 依賴工程的事情就不必關(guān)心了。

接下來設(shè)置 module 生效和 GOPROXY,命令如下:

在項(xiàng)目工程內(nèi),執(zhí)行初始化,calldemo 可以自定義名稱。

步驟 05:運(yùn)行代碼。執(zhí)行代碼,將看到下面的效果,以及最終輸出的 2020。

上述輸出信息中,可以看到 Go 語言會(huì)自動(dòng)下載依賴文件,這就是 go mod 的神奇之處。看到 2020,相信讀者也知道運(yùn)行結(jié)果是正確的了。

用Go來做以太坊開發(fā)⑤事件日志

智能合約具有在執(zhí)行期間“發(fā)出”事件的能力。 事件在以太坊中也稱為“日志”。 事件的輸出存儲(chǔ)在日志部分下的事務(wù)處理中。 事件已經(jīng)在以太坊智能合約中被廣泛使用,以便在發(fā)生相對(duì)重要的動(dòng)作時(shí)記錄,特別是在代幣合約(即ERC-20)中,以指示代幣轉(zhuǎn)賬已經(jīng)發(fā)生。 這些部分將引導(dǎo)您完成從區(qū)塊鏈中讀取事件以及訂閱事件的過程,以便交易事務(wù)被礦工打包入塊的時(shí)候及時(shí)收到通知。

為了訂閱事件日志,我們需要做的第一件事就是撥打啟用websocket的以太坊客戶端。 幸運(yùn)的是,Infura支持websockets。

下一步是創(chuàng)建篩選查詢。 在這個(gè)例子中,我們將閱讀來自我們?cè)谥罢n程中創(chuàng)建的示例合約中的所有事件。

我們接收事件的方式是通過Go channel。 讓我們從go-ethereum core/types 包創(chuàng)建一個(gè)類型為 Log 的channel。

現(xiàn)在我們所要做的就是通過從客戶端調(diào)用 SubscribeFilterLogs 來訂閱,它接收查詢選項(xiàng)和輸出通道。 這將返回包含unsubscribe和error方法的訂閱結(jié)構(gòu)。

最后,我們要做的就是使用select語句設(shè)置一個(gè)連續(xù)循環(huán)來讀入新的日志事件或訂閱錯(cuò)誤。

我們會(huì)在下個(gè)章節(jié)介紹如何解析日志。

Commands

Store.sol

event_subscribe.go

智能合約可以可選地釋放“事件”,其作為交易收據(jù)的一部分存儲(chǔ)日志。讀取這些事件相當(dāng)簡單。首先我們需要構(gòu)造一個(gè)過濾查詢。我們從go-ethereum包中導(dǎo)入 FilterQuery 結(jié)構(gòu)體并用過濾選項(xiàng)初始化它。我們告訴它我們想過濾的區(qū)塊范圍并指定從中讀取此日志的合約地址。在示例中,我們將從在 智能合約章節(jié) 創(chuàng)建的智能合約中讀取特定區(qū)塊所有日志。

下一步是調(diào)用ethclient的 FilterLogs ,它接收我們的查詢并將返回所有的匹配事件日志。

返回的所有日志將是ABI編碼,因此它們本身不會(huì)非常易讀。為了解碼日志,我們需要導(dǎo)入我們智能合約的ABI。為此,我們導(dǎo)入編譯好的智能合約Go包,它將包含名稱格式為 ContractABI 的外部屬性。之后,我們使用go-ethereum中的 accounts/abi 包的 abi.JSON 函數(shù)返回一個(gè)我們可以在Go應(yīng)用程序中使用的解析過的ABI接口。

現(xiàn)在我們可以通過日志進(jìn)行迭代并將它們解碼為我么可以使用的類型。若您回憶起我們的樣例合約釋放的日志在Solidity中是類型為 bytes32 ,那么Go中的等價(jià)物將是 [32]byte 。我們可以使用這些類型創(chuàng)建一個(gè)匿名結(jié)構(gòu)體,并將指針作為第一個(gè)參數(shù)傳遞給解析后的ABI接口的 Unpack 函數(shù),以解碼原始的日志數(shù)據(jù)。第二個(gè)參數(shù)是我們嘗試解碼的事件名稱,最后一個(gè)參數(shù)是編碼的日志數(shù)據(jù)。

此外,日志結(jié)構(gòu)體包含附加信息,例如,區(qū)塊摘要,區(qū)塊號(hào)和交易摘要。

若您的solidity事件包含 indexed 事件類型,那么它們將成為 主題 而不是日志的數(shù)據(jù)屬性的一部分。在solidity中您最多只能有4個(gè)主題,但只有3個(gè)可索引的事件類型。第一個(gè)主題總是事件的簽名。我們的示例合約不包含可索引的事件,但如果它確實(shí)包含,這是如何讀取事件主題。

正如您所見,首個(gè)主題只是被哈希過的事件簽名。

這就是閱讀和解析日志的全部內(nèi)容。要學(xué)習(xí)如何訂閱日志,閱讀上個(gè)章節(jié)。

命令

Store.sol

event_read.go

首先,創(chuàng)建ERC-20智能合約的事件日志的interface文件 erc20.sol :

然后在給定abi使用 abigen 創(chuàng)建Go包

現(xiàn)在在我們的Go應(yīng)用程序中,讓我們創(chuàng)建與ERC-20事件日志簽名類型相匹配的結(jié)構(gòu)類型:

初始化以太坊客戶端

按照ERC-20智能合約地址和所需的塊范圍創(chuàng)建一個(gè)“FilterQuery”。這個(gè)例子我們會(huì)用 ZRX 代幣:

用 FilterLogs 來過濾日志:

接下來我們將解析JSON abi,稍后我們將使用解壓縮原始日志數(shù)據(jù):

為了按某種日志類型進(jìn)行過濾,我們需要弄清楚每個(gè)事件日志函數(shù)簽名的keccak256哈希值。 事件日志函數(shù)簽名哈希始終是 topic [0] ,我們很快就會(huì)看到。 以下是使用go-ethereum crypto 包計(jì)算keccak256哈希的方法:

現(xiàn)在我們將遍歷所有日志并設(shè)置switch語句以按事件日志類型進(jìn)行過濾:

現(xiàn)在要解析 Transfer 事件日志,我們將使用 abi.Unpack 將原始日志數(shù)據(jù)解析為我們的日志類型結(jié)構(gòu)。 解包不會(huì)解析 indexed 事件類型,因?yàn)樗鼈兇鎯?chǔ)在 topics 下,所以對(duì)于那些我們必須單獨(dú)解析,如下例所示:

Approval 日志也是類似的方法:

最后,把所有的步驟放一起:

我們可以把解析的日志與etherscan的數(shù)據(jù)對(duì)比:

Commands

erc20.sol

event_read_erc20.go

solc version used for these examples

要讀取 0x Protocol 事件日志,我們必須首先將solidity智能合約編譯為一個(gè)Go包。

安裝solc版本 0.4.11

為例如 Exchange.sol 的事件日志創(chuàng)建0x Protocol交易所智能合約接口:

Create the 0x protocol exchange smart contract interface for event logs as Exchange.sol :

接著給定abi,使用 abigen 來創(chuàng)建Go exchange 包:

Then use abigen to create the Go exchange package given the abi:

現(xiàn)在在我們的Go應(yīng)用程序中,讓我們創(chuàng)建與0xProtocol事件日志簽名類型匹配的結(jié)構(gòu)體類型:

初始化以太坊客戶端:

創(chuàng)建一個(gè) FilterQuery ,并為其傳遞0x Protocol智能合約地址和所需的區(qū)塊范圍:

用 FilterLogs 查詢?nèi)罩荆?/p>

接下來我們將解析JSON abi,我們后續(xù)將使用解壓縮原始日志數(shù)據(jù):

為了按某種日志類型過濾,我們需要知曉每個(gè)事件日志函數(shù)簽名的keccak256摘要。正如我們很快所見到的那樣,事件日志函數(shù)簽名摘要總是 topic[0] :

現(xiàn)在我們迭代所有的日志并設(shè)置一個(gè)switch語句來按事件日志類型過濾:

現(xiàn)在要解析 LogFill ,我們將使用 abi.Unpack 將原始數(shù)據(jù)類型解析為我們自定義的日志類型結(jié)構(gòu)體。Unpack不會(huì)解析 indexed 事件類型,因?yàn)檫@些它們存儲(chǔ)在 topics 下,所以對(duì)于那些我們必須單獨(dú)解析,如下例所示:

對(duì)于 LogCancel 類似:

最后是 LogError :

將它們放在一起并運(yùn)行我們將看到以下輸出:

將解析后的日志輸出與etherscan上的內(nèi)容進(jìn)行比較:

命令

Exchange.sol

event_read_0xprotocol.go

這些示例使用的solc版本

以太坊是什么丨以太坊開發(fā)入門指南

以太坊是什么丨以太坊開發(fā)入門指南

很多同學(xué)已經(jīng)躍躍欲試投入到區(qū)塊鏈開發(fā)隊(duì)伍當(dāng)中來,可是又感覺無從下手,本文將基于以太坊平臺(tái),以通俗的方式介紹以太坊開發(fā)中涉及的各晦澀的概念,輕松帶大家入門。

以太坊是什么

以太坊(Ethereum)是一個(gè)建立在區(qū)塊鏈技術(shù)之上, 去中心化應(yīng)用平臺(tái)。它允許任何人在平臺(tái)中建立和使用通過區(qū)塊鏈技術(shù)運(yùn)行的去中心化應(yīng)用。

對(duì)這句話不理解的同學(xué),姑且可以理解為以太坊是區(qū)塊鏈里的Android,它是一個(gè)開發(fā)平臺(tái),讓我們就可以像基于Android Framework一樣基于區(qū)塊鏈技術(shù)寫應(yīng)用。

在沒有以太坊之前,寫區(qū)塊鏈應(yīng)用是這樣的:拷貝一份比特幣代碼,然后去改底層代碼如加密算法,共識(shí)機(jī)制,網(wǎng)絡(luò)協(xié)議等等(很多山寨幣就是這樣,改改就出來一個(gè)新幣)。

以太坊平臺(tái)對(duì)底層區(qū)塊鏈技術(shù)進(jìn)行了封裝,讓區(qū)塊鏈應(yīng)用開發(fā)者可以直接基于以太坊平臺(tái)進(jìn)行開發(fā),開發(fā)者只要專注于應(yīng)用本身的開發(fā),從而大大降低了難度。

目前圍繞以太坊已經(jīng)形成了一個(gè)較為完善的開發(fā)生態(tài)圈:有社區(qū)的支持,有很多開發(fā)框架、工具可以選擇。

智能合約

什么是智能合約

以太坊上的程序稱之為智能合約, 它是代碼和數(shù)據(jù)(狀態(tài))的集合。

智能合約可以理解為在區(qū)塊鏈上可以自動(dòng)執(zhí)行的(由事件驅(qū)動(dòng)的)、以代碼形式編寫的合同(特殊的交易)。

在比特幣腳本中,我們講到過比特幣的交易是可以編程的,但是比特幣腳本有很多的限制,能夠編寫的程序也有限,而以太坊則更加完備(在計(jì)算機(jī)科學(xué)術(shù)語中,稱它為是“圖靈完備的”),讓我們就像使用任何高級(jí)語言一樣來編寫幾乎可以做任何事情的程序(智能合約)。

智能合約非常適合對(duì)信任、安全和持久性要求較高的應(yīng)用場景,比如:數(shù)字貨幣、數(shù)字資產(chǎn)、投票、保險(xiǎn)、金融應(yīng)用、預(yù)測(cè)市場、產(chǎn)權(quán)所有權(quán)管理、物聯(lián)網(wǎng)、點(diǎn)對(duì)點(diǎn)交易等等。

目前除數(shù)字貨幣之外,真正落地的應(yīng)用還不多(就像移動(dòng)平臺(tái)剛開始出來一樣),相信1到3年內(nèi),各種殺手級(jí)會(huì)慢慢出現(xiàn)。

編程語言:Solidity

智能合約的默認(rèn)的編程語言是Solidity,文件擴(kuò)展名以.sol結(jié)尾。

Solidity是和JavaScript相似的語言,用它來開發(fā)合約并編譯成以太坊虛擬機(jī)字節(jié)代碼。

還有長像Python的智能合約開發(fā)語言:Serpent,不過建議大家還是使用Solidity。

Browser-Solidity是一個(gè)瀏覽器的Solidity IDE, 大家可以點(diǎn)進(jìn)去看看,以后我們更多文章介紹Solidity這個(gè)語言。

運(yùn)行環(huán)境:EVM

EVM(Ethereum Virtual Machine)以太坊虛擬機(jī)是以太坊中智能合約的運(yùn)行環(huán)境。

Solidity之于EVM,就像之于跟JVM的關(guān)系一樣,這樣大家就容易理解了。

以太坊虛擬機(jī)是一個(gè)隔離的環(huán)境,在EVM內(nèi)部運(yùn)行的代碼不能跟外部有聯(lián)系。

而EVM運(yùn)行在以太坊節(jié)點(diǎn)上,當(dāng)我們把合約部署到以太坊網(wǎng)絡(luò)上之后,合約就可以在以太坊網(wǎng)絡(luò)中運(yùn)行了。

合約的編譯

以太坊虛擬機(jī)上運(yùn)行的是合約的字節(jié)碼形式,需要我們?cè)诓渴鹬跋葘?duì)合約進(jìn)行編譯,可以選擇Browser-Solidity Web IDE或solc編譯器。

合約的部署

在以太坊上開發(fā)應(yīng)用時(shí),常常要使用到以太坊客戶端(錢包)。平時(shí)我們?cè)陂_發(fā)中,一般不接觸到客戶端或錢包的概念,它是什么呢?

以太坊客戶端(錢包)

以太坊客戶端,其實(shí)我們可以把它理解為一個(gè)開發(fā)者工具,它提供賬戶管理、挖礦、轉(zhuǎn)賬、智能合約的部署和執(zhí)行等等功能。

EVM是由以太坊客戶端提供的。

Geth是典型的開發(fā)以太坊時(shí)使用的客戶端,基于Go語言開發(fā)。 Geth提供了一個(gè)交互式命令控制臺(tái),通過命令控制臺(tái)中包含了以太坊的各種功能(API)。Geth的使用我們之后會(huì)有文章介紹,這里大家先有個(gè)概念。

Geth控制臺(tái)和Chrome瀏覽器開發(fā)者工具里的面的控制臺(tái)是類似,不過是跑在終端里。

相對(duì)于Geth,Mist則是圖形化操作界面的以太坊客戶端。

如何部署

智能合約的部署是指把合約字節(jié)碼發(fā)布到區(qū)塊鏈上,并使用一個(gè)特定的地址來標(biāo)示這個(gè)合約,這個(gè)地址稱為合約賬戶。

以太坊中有兩類賬戶:

· 外部賬戶

該類賬戶被私鑰控制(由人控制),沒有關(guān)聯(lián)任何代碼。

· 合約賬戶

該類賬戶被它們的合約代碼控制且有代碼與之關(guān)聯(lián)。

和比特幣使用UTXO的設(shè)計(jì)不一樣,以太坊使用更為簡單的賬戶概念。

兩類賬戶對(duì)于EVM來說是一樣的。

外部賬戶與合約賬戶的區(qū)別和關(guān)系是這樣的:一個(gè)外部賬戶可以通過創(chuàng)建和用自己的私鑰來對(duì)交易進(jìn)行簽名,來發(fā)送消息給另一個(gè)外部賬戶或合約賬戶。

在兩個(gè)外部賬戶之間傳送消息是價(jià)值轉(zhuǎn)移的過程。但從外部賬戶到合約賬戶的消息會(huì)激活合約賬戶的代碼,允許它執(zhí)行各種動(dòng)作(比如轉(zhuǎn)移代幣,寫入內(nèi)部存儲(chǔ),挖出一個(gè)新代幣,執(zhí)行一些運(yùn)算,創(chuàng)建一個(gè)新的合約等等)。

只有當(dāng)外部賬戶發(fā)出指令時(shí),合同賬戶才會(huì)執(zhí)行相應(yīng)的操作。

合約部署就是將編譯好的合約字節(jié)碼通過外部賬號(hào)發(fā)送交易的形式部署到以太坊區(qū)塊鏈上(由實(shí)際礦工出塊之后,才真正部署成功)。

運(yùn)行

合約部署之后,當(dāng)需要調(diào)用這個(gè)智能合約的方法時(shí)只需要向這個(gè)合約賬戶發(fā)送消息(交易)即可,通過消息觸發(fā)后智能合約的代碼就會(huì)在EVM中執(zhí)行了。

Gas

和云計(jì)算相似,占用區(qū)塊鏈的資源(不管是簡單的轉(zhuǎn)賬交易,還是合約的部署和執(zhí)行)同樣需要付出相應(yīng)的費(fèi)用(天下沒有免費(fèi)的午餐對(duì)不對(duì)!)。

以太坊上用Gas機(jī)制來計(jì)費(fèi),Gas也可以認(rèn)為是一個(gè)工作量單位,智能合約越復(fù)雜(計(jì)算步驟的數(shù)量和類型,占用的內(nèi)存等),用來完成運(yùn)行就需要越多Gas。

任何特定的合約所需的運(yùn)行合約的Gas數(shù)量是固定的,由合約的復(fù)雜度決定。

而Gas價(jià)格由運(yùn)行合約的人在提交運(yùn)行合約請(qǐng)求的時(shí)候規(guī)定,以確定他愿意為這次交易愿意付出的費(fèi)用:Gas價(jià)格(用以太幣計(jì)價(jià)) * Gas數(shù)量。

Gas的目的是限制執(zhí)行交易所需的工作量,同時(shí)為執(zhí)行支付費(fèi)用。當(dāng)EVM執(zhí)行交易時(shí),Gas將按照特定規(guī)則被逐漸消耗,無論執(zhí)行到什么位置,一旦Gas被耗盡,將會(huì)觸發(fā)異常。當(dāng)前調(diào)用幀所做的所有狀態(tài)修改都將被回滾, 如果執(zhí)行結(jié)束還有Gas剩余,這些Gas將被返還給發(fā)送賬戶。

如果沒有這個(gè)限制,就會(huì)有人寫出無法停止(如:死循環(huán))的合約來阻塞網(wǎng)絡(luò)。

因此實(shí)際上(把前面的內(nèi)容串起來),我們需要一個(gè)有以太幣余額的外部賬戶,來發(fā)起一個(gè)交易(普通交易或部署、運(yùn)行一個(gè)合約),運(yùn)行時(shí),礦工收取相應(yīng)的工作量費(fèi)用。

以太坊網(wǎng)絡(luò)

有些著急的同學(xué)要問了,沒有以太幣,要怎么進(jìn)行智能合約的開發(fā)?可以選擇以下方式:

選擇以太坊官網(wǎng)測(cè)試網(wǎng)絡(luò)Testnet

測(cè)試網(wǎng)絡(luò)中,我們可以很容易獲得免費(fèi)的以太幣,缺點(diǎn)是需要發(fā)很長時(shí)間初始化節(jié)點(diǎn)。

使用私有鏈

創(chuàng)建自己的以太幣私有測(cè)試網(wǎng)絡(luò),通常也稱為私有鏈,我們可以用它來作為一個(gè)測(cè)試環(huán)境來開發(fā)、調(diào)試和測(cè)試智能合約。

通過上面提到的Geth很容易就可以創(chuàng)建一個(gè)屬于自己的測(cè)試網(wǎng)絡(luò),以太幣想挖多少挖多少,也免去了同步正式網(wǎng)絡(luò)的整個(gè)區(qū)塊鏈數(shù)據(jù)。

使用開發(fā)者網(wǎng)絡(luò)(模式)

相比私有鏈,開發(fā)者網(wǎng)絡(luò)(模式)下,會(huì)自動(dòng)分配一個(gè)有大量余額的開發(fā)者賬戶給我們使用。

使用模擬環(huán)境

另一個(gè)創(chuàng)建測(cè)試網(wǎng)絡(luò)的方法是使用testrpc,testrpc是在本地使用內(nèi)存模擬的一個(gè)以太坊環(huán)境,對(duì)于開發(fā)調(diào)試來說,更方便快捷。而且testrpc可以在啟動(dòng)時(shí)幫我們創(chuàng)建10個(gè)存有資金的測(cè)試賬戶。

進(jìn)行合約開發(fā)時(shí),可以在testrpc中測(cè)試通過后,再部署到Geth節(jié)點(diǎn)中去。

更新:testrpc 現(xiàn)在已經(jīng)并入到Truffle 開發(fā)框架中,現(xiàn)在名字是Ganache CLI。

Dapp:去中心化的應(yīng)用程序

以太坊社區(qū)把基于智能合約的應(yīng)用稱為去中心化的應(yīng)用程序(DecentralizedApp)。如果我們把區(qū)塊鏈理解為一個(gè)不可篡改的數(shù)據(jù)庫,智能合約理解為和數(shù)據(jù)庫打交道的程序,那就很容易理解Dapp了,一個(gè)Dapp不單單有智能合約,比如還需要有一個(gè)友好的用戶界面和其他的東西。

Truffle

Truffle是Dapp開發(fā)框架,他可以幫我們處理掉大量無關(guān)緊要的小事情,讓我們可以迅速開始寫代碼-編譯-部署-測(cè)試-打包DApp這個(gè)流程。

總結(jié)

我們現(xiàn)在來總結(jié)一下,以太坊是平臺(tái),它讓我們方便的使用區(qū)塊鏈技術(shù)開發(fā)去中心化的應(yīng)用,在這個(gè)應(yīng)用中,使用Solidity來編寫和區(qū)塊鏈交互的智能合約,合約編寫好后之后,我們需要用以太坊客戶端用一個(gè)有余額的賬戶去部署及運(yùn)行合約(使用Truffle框架可以更好的幫助我們做這些事情了)。為了開發(fā)方便,我們可以用Geth或testrpc來搭建一個(gè)測(cè)試網(wǎng)絡(luò)。

注:本文中為了方便大家理解,對(duì)一些概念做了類比,有些嚴(yán)格來不是準(zhǔn)確,不過我也認(rèn)為對(duì)于初學(xué)者,也沒有必要把每一個(gè)概念掌握的很細(xì)致和準(zhǔn)確,學(xué)習(xí)是一個(gè)逐步深入的過程,很多時(shí)候我們會(huì)發(fā)現(xiàn),過一段后,我們會(huì)對(duì)同一個(gè)東西有不一樣的理解。

大壹幣推出的以太坊170M礦機(jī)怎么樣?安全嗎?

以太坊的礦機(jī)還是很不錯(cuò)的,這一款礦機(jī)是實(shí)體礦機(jī),安全性很高的。中本聰以一己之力奠定了比特幣的理論基礎(chǔ),而以太坊,不僅站在了比特幣的基石之上,還用比特幣眾籌的方式,一方面儲(chǔ)備了足夠的啟動(dòng)資金,另一方面還積累了廣大的種子用戶群,更重要的是贏得了來自全球的關(guān)注和期待,相對(duì)于比特幣早期的默默無聞,以太坊簡直就是含著金鑰匙出生的世家子弟,可以說真正贏在了起跑線上。以太坊采用多種編程語言實(shí)現(xiàn)協(xié)議,Go語言寫的客戶端作為默認(rèn)客戶端。在多編程語言競爭的環(huán)境下,獲得了最符合規(guī)劃思想的成品。

當(dāng)前題目:以太坊可以用go語言,以太坊 go語言
URL分享:http://chinadenli.net/article23/dsidgjs.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供電子商務(wù)網(wǎng)站維護(hù)App開發(fā)品牌網(wǎng)站設(shè)計(jì)App設(shè)計(jì)定制開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司