以太坊是什么?以太坊開發(fā)入門指南
以太坊是什么
以太坊(Ethereum)是一個建立在區(qū)塊鏈技術(shù)之上, 去中心化應(yīng)用平臺。它允許任何人在平臺中建立和使用通過區(qū)塊鏈技術(shù)運行的去中心化應(yīng)用。
對這句話不理解的同學(xué),姑且可以理解為以太坊是區(qū)塊鏈里的Android,它是一個開發(fā)平臺,讓我們就可以像基于Android Framework一樣基于區(qū)塊鏈技術(shù)寫應(yīng)用。
在沒有以太坊之前,寫區(qū)塊鏈應(yīng)用是這樣的:拷貝一份比特幣代碼,然后去改底層代碼如加密算法,共識機制,網(wǎng)絡(luò)協(xié)議等等(很多山寨幣就是這樣,改改就出來一個新幣)。
以太坊平臺對底層區(qū)塊鏈技術(shù)進行了封裝,讓區(qū)塊鏈應(yīng)用開發(fā)者可以直接基于以太坊平臺進行開發(fā),開發(fā)者只要專注于應(yīng)用本身的開發(fā),從而大大降低了難度。
目前圍繞以太坊已經(jīng)形成了一個較為完善的開發(fā)生態(tài)圈:有社區(qū)的支持,有很多開發(fā)框架、工具可以選擇。
智能合約
什么是智能合約
以太坊上的程序稱之為智能合約, 它是代碼和數(shù)據(jù)(狀態(tài))的集合。
智能合約可以理解為在區(qū)塊鏈上可以自動執(zhí)行的(由事件驅(qū)動的)、以代碼形式編寫的合同(特殊的交易)。
在比特幣腳本中,我們講到過比特幣的交易是可以編程的,但是比特幣腳本有很多的限制,能夠編寫的程序也有限,
而以太坊則更加完備(在計算機科學(xué)術(shù)語中,稱它為是“圖靈完備的”),讓我們就像使用任何高級語言一樣來編寫幾乎可以做任何事情的程序(智能合約)。
智能合約非常適合對信任、安全和持久性要求較高的應(yīng)用場景,比如:數(shù)字貨幣、數(shù)字資產(chǎn)、投票、保險、金融應(yīng)用、預(yù)測市場、產(chǎn)權(quán)所有權(quán)管理、物聯(lián)網(wǎng)、點對點交易等等。
目前除數(shù)字貨幣之外,真正落地的應(yīng)用還不多(就像移動平臺剛開始出來一樣),相信1到3年內(nèi),各種殺手級會慢慢出現(xiàn)。
編程語言:Solidity
智能合約的默認的編程語言是Solidity,文件擴展名以.sol結(jié)尾。
Solidity是和JavaScript相似的語言,用它來開發(fā)合約并編譯成以太坊虛擬機字節(jié)代碼。
還有長得像Python的智能合約開發(fā)語言:Serpent,不過建議大家還是使用Solidity。
Browser-Solidity是一個瀏覽器的Solidity IDE, 大家可以點進去看看,以后我們更多文章介紹Solidity這個語言。
運行環(huán)境:EVM
EVM(Ethereum Virtual Machine)以太坊虛擬機是以太坊中智能合約的運行環(huán)境。
Solidity之于EVM,就像之于跟JVM的關(guān)系一樣,這樣大家就容易理解了。
以太坊虛擬機是一個隔離的環(huán)境,在EVM內(nèi)部運行的代碼不能跟外部有聯(lián)系。
而EVM運行在以太坊節(jié)點上,當我們把合約部署到以太坊網(wǎng)絡(luò)上之后,合約就可以在以太坊網(wǎng)絡(luò)中運行了。
合約的編譯
以太坊虛擬機上運行的是合約的字節(jié)碼形式,需要我們在部署之前先對合約進行編譯,可以選擇Browser-Solidity Web IDE或solc編譯器。
合約的部署
在以太坊上開發(fā)應(yīng)用時,常常要使用到以太坊客戶端(錢包)。平時我們在開發(fā)中,一般不接觸到客戶端或錢包的概念,它是什么呢?
以太坊客戶端(錢包)
以太坊客戶端,其實我們可以把它理解為一個開發(fā)者工具,它提供賬戶管理、挖礦、轉(zhuǎn)賬、智能合約的部署和執(zhí)行等等功能。
EVM是由以太坊客戶端提供的
Geth是典型的開發(fā)以太坊時使用的客戶端,基于Go語言開發(fā)。 Geth提供了一個交互式命令控制臺,通過命令控制臺中包含了以太坊的各種功能(API)。Geth的使用我們之后會有文章介紹,這里大家先有個概念。
Geth控制臺和Chrome瀏覽器開發(fā)者工具里的面的控制臺是類似的,不過Geth控制臺是跑在終端里。
相對于Geth,Mist則是圖形化操作界面的以太坊客戶端。
如何部署
智能合約的部署是指把合約字節(jié)碼發(fā)布到區(qū)塊鏈上,并使用一個特定的地址來標示這個合約,這個地址稱為合約賬戶。
以太坊中有兩類賬戶:
- 外部賬戶:該類賬戶被私鑰控制(由人控制),沒有關(guān)聯(lián)任何代碼。
- 合約賬戶:該類賬戶被它們的合約代碼控制且有代碼與之關(guān)聯(lián)。
和比特幣使用UTXO的設(shè)計不一樣,以太坊使用更為簡單的賬戶概念。
兩類賬戶對于EVM來說是一樣的。
外部賬戶與合約賬戶的區(qū)別和關(guān)系是這樣的:一個外部賬戶可以通過創(chuàng)建和用自己的私鑰來對交易進行簽名,來發(fā)送消息給另一個外部賬戶或合約賬戶。
在兩個外部賬戶之間傳送消息是價值轉(zhuǎn)移的過程。但從外部賬戶到合約賬戶的消息會激活合約賬戶的代碼,允許它執(zhí)行各種動作(比如轉(zhuǎn)移代幣,寫入內(nèi)部存儲,挖出一個新代幣,執(zhí)行一些運算,創(chuàng)建一個新的合約等等)。
只有當外部賬戶發(fā)出指令時,合同賬戶才會執(zhí)行相應(yīng)的操作。
合約部署就是將編譯好的合約字節(jié)碼通過外部賬號發(fā)送交易的形式部署到以太坊區(qū)塊鏈上(由實際礦工出塊之后,才真正部署成功)。
運行
合約部署之后,當需要調(diào)用這個智能合約的方法時只需要向這個合約賬戶發(fā)送消息(交易)即可,通過消息觸發(fā)后智能合約的代碼就會在EVM中執(zhí)行了。
Gas
和云計算相似,占用區(qū)塊鏈的資源(不管是簡單的轉(zhuǎn)賬交易,還是合約的部署和執(zhí)行)同樣需要付出相應(yīng)的費用(天下沒有免費的午餐對不對!)。
以太坊上用Gas機制來計費,Gas也可以認為是一個工作量單位,智能合約越復(fù)雜(計算步驟的數(shù)量和類型,占用的內(nèi)存等),用來完成運行就需要越多Gas。
任何特定的合約所需的運行合約的Gas數(shù)量是固定的,由合約的復(fù)雜度決定。
而Gas價格由運行合約的人在提交運行合約請求的時候規(guī)定,以確定他愿意為這次交易愿意付出的費用:Gas價格(用以太幣計價) * Gas數(shù)量。
Gas的目的是限制執(zhí)行交易所需的工作量,同時為執(zhí)行支付費用。當EVM執(zhí)行交易時,Gas將按照特定規(guī)則被逐漸消耗,無論執(zhí)行到什么位置,一旦Gas被耗盡,將會觸發(fā)異常。當前調(diào)用幀所做的所有狀態(tài)修改都將被回滾, 如果執(zhí)行結(jié)束還有Gas剩余,這些Gas將被返還給發(fā)送賬戶。
如果沒有這個限制,就會有人寫出無法停止(如:死循環(huán))的合約來阻塞網(wǎng)絡(luò)。
因此實際上(把前面的內(nèi)容串起來),我們需要一個有以太幣余額的外部賬戶,來發(fā)起一個交易(普通交易或部署、運行一個合約),運行時,礦工收取相應(yīng)的工作量費用。智能合約的部署是指把合約字節(jié)碼發(fā)布到區(qū)塊鏈上,并使用一個特定的地址來標示這個合約,這個地址稱為合約賬戶。
測試網(wǎng)絡(luò):私有鏈
有些著急的同學(xué)要問了,我沒有以太幣,要怎么進行智能合約的開發(fā)?
答案是創(chuàng)建自己的以太幣私有測試網(wǎng)絡(luò),通常也稱為私有鏈,我們可以用它來作為一個測試環(huán)境來開發(fā)、調(diào)試和測試智能合約。
通過上面提到的Geth很容易就可以創(chuàng)建一個屬于自己的測試網(wǎng)絡(luò),以太幣想挖多少挖多少,也免去了同步正式網(wǎng)絡(luò)的整個區(qū)塊鏈數(shù)據(jù)。
另一個創(chuàng)建測試網(wǎng)絡(luò)的方法是使用testrpc,testrpc是在本地使用內(nèi)存模擬的一個以太坊環(huán)境,對于開發(fā)調(diào)試來說,更方便快捷。而且testrpc可以在啟動時幫我們創(chuàng)建一堆存有資金的測試賬戶。
進行合約開發(fā)是,可以在testrpc中測試通過后,再部署到Geth中去。
Dapp:去中心化的應(yīng)用程序
以太坊社區(qū)把基于智能合約的應(yīng)用稱為去中心化的應(yīng)用程序(Decentralized App)。如果我們把區(qū)塊鏈理解為一個不可篡改的數(shù)據(jù)庫,智能合約理解為和數(shù)據(jù)庫打交道的程序,那就很容易理解Dapp了,一個Dapp不單單有智能合約,比如還需要有一個友好的用戶界面和其他的東西。
Truffle
Truffle是Dapp開發(fā)框架,他可以幫我們處理掉大量無關(guān)緊要的小事情,讓我們可以迅速開始寫代碼-編譯-部署-測試-打包DApp這個流程。
總結(jié)
我們現(xiàn)在來總結(jié)一下,以太坊是平臺,它讓我們方便的使用區(qū)塊鏈技術(shù)開發(fā)去中心化的應(yīng)用,在這個應(yīng)用中,使用Solidity來編寫和區(qū)塊鏈交互的智能合約,合約編寫好后之后,我們需要用以太坊客戶端用一個有余額的賬戶去部署及運行合約(使用Truffle框架可以更好的幫助我們做這些事情了)。為了開發(fā)方便,我們可以用Geth或testrpc來搭建一個測試網(wǎng)絡(luò)。
注:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是準確,不過我也認為對于初學(xué)者,也沒有必要把每一個概念掌握的很細致和準確,學(xué)習(xí)是一個逐步深入的過程,很多時候我們會發(fā)現(xiàn),過一段后,我們會對同一個東西有不一樣的理解。
以上就是以太坊是什么?以太坊開發(fā)入門指南的詳細內(nèi)容,更多關(guān)于以太坊知識分享的資料請關(guān)注腳本之家其它相關(guān)文章!
你可能感興趣的文章
-
加密貨幣空投有哪些類型?如何安全領(lǐng)取空投代幣?完整指南
隨著區(qū)塊鏈技術(shù)的不斷發(fā)展,空投(Airdrop)已成為加密項推廣的重要式,簡單來說,空投就是免費發(fā)放加密貨幣,的是吸引更多戶關(guān)注項目并參與其中,對新來說,空投是種低檻的 …
2025-09-23 -
區(qū)塊瀏覽器怎么用?怎么查看鏈上數(shù)據(jù)和轉(zhuǎn)賬狀態(tài)?
區(qū)塊瀏覽器是一種專門用于查詢和瀏覽區(qū)塊鏈信息的工具,本質(zhì)上是區(qū)塊鏈的 “搜索引擎”, 它能實時瀏覽和查詢區(qū)塊鏈上的區(qū)塊高度、交易記錄、地址、代幣等信息,將復(fù)雜的鏈…
2025-09-23 -
2025年如何挖掘萊特幣 (LTC)幣?挖礦教程、收益分析
萊特幣誕生于 2011 年,是比特幣的一個分叉,旨在成為更輕量、更快速的支付網(wǎng)絡(luò),它采用 Scrypt 算法,這是一種不同于比特幣 SHA-256 的哈希算法,最初的設(shè)計目的是降低挖礦…
2025-09-23 -
什么是跨鏈橋?市面上有哪些跨鏈橋?一文介紹
什么是跨鏈橋?跨鏈橋在加密貨幣領(lǐng)域發(fā)揮著至關(guān)重要的作用,它實現(xiàn)了不同區(qū)塊鏈網(wǎng)絡(luò)之間的資產(chǎn)轉(zhuǎn)移,這是必要的,因為每個區(qū)塊鏈都按照自己的規(guī)則獨立運行,因此無法直接在…
2025-09-23 -
DeFi 3.0是什么?DeFi 3.0 代幣、功能、工作原理介紹
去中心化金融 (DeFi) 已經(jīng)徹底改變了人們對貨幣、借貸和投資的認知,從早期簡單的借貸協(xié)議到如今高度復(fù)雜的收益挖礦方法,DeFi 不斷發(fā)展演變,這種演變的最新階段就是人們所…
2025-09-23 -
DePINFi是什么?有哪些分類?DePINFi的趨勢的優(yōu)勢和挑戰(zhàn)介紹
DePINFi 是“去中心化物理基礎(chǔ)設(shè)施網(wǎng)絡(luò)金融”的縮寫,是去中心化物理基礎(chǔ)設(shè)施網(wǎng)絡(luò) (DePIN) 與去中心化金融 (DeFi) 的交匯點,下面小編就為大家詳細介紹一下它吧…
2025-09-22 -
Base生態(tài)核心項目有哪些?一文速覽值得關(guān)注的20個Base生態(tài)項目
本文將推薦Base生態(tài)中值得關(guān)注的20個項目,通過梳理這些項目的市場定位和資本表現(xiàn),來判斷Base生態(tài)的真實厚度,并進一步揭示其未來增長的動力來源,這不僅是對Base App轉(zhuǎn)型…
2025-09-22 -
一文盤點Web3 AI的11個潛力項目:不要錯過的造富列車
Web3 AI為普通人提供了參與AI財富創(chuàng)造的機會,不同于傳統(tǒng)AI的精英化,以下是我們精選的 Web3 AI領(lǐng)域最具潛力的項目和方向,Web3 AI的造富列車已經(jīng)啟動,現(xiàn)在上車還來得及…
2025-09-22 -
什么是加密貨幣完全稀釋估值FDV?怎么算?為何代幣解鎖可能意味著上漲
什么是加密貨幣完全稀釋估值FDV?為何代幣解鎖可能意味著上漲?FDV 考慮的是代幣的總供應(yīng)量,而流通供應(yīng)量指的是當前市場上實際交易的代幣,理解 FDV 有助于全面評估一個項…
2025-09-20 -
什么是加密貨幣市值?市值為何重要?如何影響加密貨幣價格?
市值,通常被稱為“市值”,是一個反映加密貨幣總價值的財務(wù)指標,它是通過將加密貨幣的當前價格乘以其總流通供應(yīng)量來計算的,本文深入探討了加密貨幣市值的含義、計算方法以…
2025-09-19