前言:智能合約這個詞你可能聽過無數遍,但有多少人真正理解什么是智能合約?本文幫你深入理解以太坊智能合約。本文作者是GjermundBjaanes,由“藍狐筆記”社群的“Dyna”翻譯。
你可能聽說過“智能合約”,甚至可能知道它們是在區塊鏈上運行的代碼。
但是你如何才能在區塊鏈上運行代碼?這不是可以輕易理解的簡單概念。
本文解釋了智能合約是如何在以太坊區塊鏈上運行的。對編程的基礎理解將會有所幫助,因為本文包含了一些用于舉例的簡單代碼。為了清晰起見,本文將其中的一些技術細節稍微進行了簡化,但概念是有效的。
區塊鏈-快速入門
這里不講太多細節,區塊鏈技術的核心概念是分布式賬本。它是一種在眾多參與者之間共享的特殊類型的數據庫。
這個特殊的數據庫就是一個交易列表,記錄了網絡中發生的每一筆交易。每個人都有一個副本。這種去中心化分布結合強有力的貨幣激勵措施,消除了各方之間信任的必要性。
傳統意義上,當事人之間的信任是通過中間人,即第三方來解決的,比如Paypal、銀行。與你不信任的人之間的交易將通過雙方都信任的中間人進行。
有了區塊鏈,這種需求消失了。因為你可以把你的信任放在網絡上,在這里,強有力的激勵措施消除了作弊欺騙的欲望(簡而言之:遵守規則更有利可圖)。
IOTA聯合創始人:比特幣和以太坊并沒有真正實現去中心化:7月6日消息,IOTA聯合創始人David S?nsteb?在最近的一次采訪中表示,比特幣和以太坊并沒有實現真正地去中心化。他稱,比特幣和以太坊都需要通過采礦來運作。而這會導致需要復雜昂貴的礦機設備,會導致兩個加密貨幣的集中化。在任何工作量證明(PoW)生態系統中,如果實體擁有足夠的資源來進行大規模挖礦,那么它將對網絡產生重大影響。(Coinjournal)[2020/7/7]
更具體地說:區塊鏈網絡是一組機器,它們記錄著相同的交易列表副本(例如,從A轉給B的錢)。
因為每個人都有相同的列表,所以很難欺騙網絡接受錯誤的交易。結合一些加密算法和貨幣獎勵以便遵守規則,你的網絡會非常安全。
所有這些也使得區塊鏈幾乎是不可變的,因為改變歷史記錄的唯一方法是獲得全網大多數人的同意。
什么是智能合約?
區別于比特幣,以太坊最大的不同是引入了智能合約的概念。比特幣是數字貨幣,以太坊也是數字貨幣,但遠不止這些。
“智能合約”這個名稱有點誤導人。它們不是真正的合約,也不特別智能。它們只是一些可以運行在區塊鏈上的代碼-或者說是計算機邏輯運算。
首先,我將介紹有關智能合約是以太坊網絡上的一種特殊賬戶。你有用戶賬戶,你還有智能合約賬戶。
獨家 | 大山: 挖礦是能真正穿越牛熊的一種商業邏輯:在今晚由算力互聯主辦,金色財經獨家支持直播的2020礦業新勢力AMA上,針對“水滴資本在實際運作礦業基金以及進行礦業生態布局,這個過程中,有哪些心得體會或者感悟?”的問題,水滴資本聯合創始人大山表示幾個合伙人都是13年以前就接觸BTC的,也見證了幾輪牛熊了,但不知道大家發現了沒有,很多圈子里曾經風光無限的人物都曇花一現消失匿跡了,而過了這些年下來留到現在的,大家調侃為大佬的人,或者行業頭部的大公司,除了少數幾家交易所外,大多跟礦業有關。這是因為挖礦是能真正穿越牛熊的一種商業邏輯。[2020/2/26]
一個用戶賬戶包括:
一個地址
余額
一個智能合約賬戶包括:
一個地址
余額
一個狀態
代碼
地址和普通賬戶的地址是一樣的,它是該賬戶的唯一識別符。
余額和普通賬戶也是一樣的概念。唯一令人激動的是,智能合約上的余額意味著代碼可以擁有金錢。它可以處理這些錢,也可能因為編碼錯誤而造成處理不當。
智能合約帳戶的狀態是智能合約中聲明的所有字段和變量的當前狀態。它的工作方式與大多數編程語言中類的字段變量相同。事實上,一個類的實體化對象可能是理解智能合約的最簡單方法。唯一的區別是這個對象是永久存在的(除非被編程為自我毀滅)。
現場 | 清華X-lab鐘宏:DCEP真正的目標是成為全球最多人口的數字化支付體系:金色財經現場報道,2020年1月12日,“2020傳媒區塊鏈高級研討會暨傳媒區塊鏈產業智庫籌備會”在中國人民大學明德樓召開。該活動由區塊鏈產業智庫、中國人民大學新聞學院現代廣告研究中心、清華大學技術創新研究中心、《媒介》雜志社、國研智庫&清華x-lab數權經濟實驗室以及區塊鏈產業人才研究所等機構聯合舉辦。清華X-lab青藤鏈研究院院長鐘宏在會上表示,區塊鏈是一個跨學科、跨領域復合型技術,傳播學是區塊鏈技術的基礎學科之一,區塊鏈本質上是實現“數字化可信傳播”。他還談到央行的DCEP,他表示,Facebook宣布發起Libra之后央行加速推動DCEP,DCEP真正的目標是成為全球最多人口的數字化支付體系。在談到習總書記1024講話時,他表示,陳純院士講的是聯盟鏈技術,公鏈不一定適合在中國發展,公鏈無法在網信辦備案。中國特色的區塊鏈技術將構建下一代的數字長城。[2020/1/12]
智能合約的代碼是編譯好的字節代碼,以太坊客戶機和節點可以在上面運行。它是在創建智能合約時執行的代碼,并且包含可以調用的函數。就像面向對象編程的語言中的任何對象一樣。
關于智能合約的趣事:它們可以調用其它的智能合約。這就開啟了創建自主代理的能力,這些代理可以自己花錢和進行交易。
聲音 | deVere Group首席執行官:BTC將迎來真正的全球突破:據BusinessCloud消息,deVere Group創始人兼CEO Nigel Green近日表示,比特幣和其他加密貨幣正處于真正全球突破的邊緣。這主要歸功于“害怕錯過”FOMO(Fear Of Missing Out)。他表示,數字貨幣越來越多的受到關注。不僅體現在金融領域,主要銀行越來越多地關注區塊鏈和加密,科技和零售領域也一樣,機構越來越感覺到,除非他們接受這個行業,否則他們的競爭對手可能會走在前面,他們可能會發現很難趕上。因為公眾 ,他們的客戶,越來越渴望自己探索這些機會。他補充說,隨著人們越來越認可他們確實是貨幣的未來,相信環境現在正好適合年底前的上漲。[2018/10/1]
假設我用上面的代碼創建了一個智能合約。該代碼有一個名為counter的字段,類型為uint(整數)。counter變量的內容是本合約的狀態。每當我調用count()函數時,任何人都能看到這個智能合約在區塊鏈上的狀態將會加1。
稍后我們將通過更多的例子來解釋它是如何工作的,但首先我想回到以太坊和比特幣的交易,并以此來解釋一些事情。
交易水平上,以太坊VS比特幣
比特幣交易非常簡單。你可以只做一件事。一種類型的交易。略過一些細節,一切都可以歸結為TO,FROM和AMOUNT。這使得比特幣成為一種價值儲存手段,能夠在網絡參與者之間傳遞價值。
金色財經現場報道 鄧迪:真正的共享經濟應該通過區塊鏈技術實現:金色財經現場報道,在今天柬埔寨金邊舉辦的2018全球區塊鏈高峰論壇上,中國區塊鏈應用研究中心理事長、太一云董事長鄧迪演講說:共享經濟一直以來是以社會資源整合者面貌出現,但是我們最后發現這些所謂的社會資源整合者最后都變成云服務提供者,不是將大家閑置的資源利用起來,來實現社會運力節省,而是采用和云計算類似模式,大量購置資產,提供給社會公民使用,所以現在共享經濟不是真正的共享經濟,可能稱為云服務更加合適。真正的共享經濟是應該通過區塊鏈技術,實現分布式資源可以上鏈、上網。[2018/4/29]
以太坊的不同之處在于交易還有一個“DATA”字段。該“DATA”字段支持三種類型的交易:
價值轉移
TO接收地址
DATA字段為空或包含要附加的任何消息
FROM你
AMOUNT是你要發送的以太坊數量
創建智能合約
TO字段為空(它觸發智能合約的創建)
DATA字段包含編譯為字節代碼的智能合約代碼
FROM你
AMOUNT可以是0或者任意你想放在合約里的以太坊數量
調用智能合約
TO字段是智能合約賬戶地址
DATA字段包含函數名稱和參數–如何調用智能合約
FROM你
AMOUNT可以是0或者任何數量的以太坊,比如你需要為一項服務合約支付的數目
在這些交易中還有更多的字段和復雜性,但以上這些已經很好地解釋了核心概念。讓我們看看關于這些交易的一些更具體的例子。
以太坊交易
價值轉移
非常簡單。TO向一個地址發送一定數目的以太坊代幣。你也可以為一筆交易加上一條消息。
創建智能合約
正如以上提到的,一個空的TO字段表示創建一份智能合約。DATA字段包含編譯為字節代碼的智能合約。
調用合約
我們稍后會回到這個問題,但是其主要概念是你將交易發送到你想要調用的智能合約地址,然后將函數調用放在DATA字段中。
注意成本和執行
正如你所想象的,你不能一直在區塊鏈上免費運行計算量很大的程序。
代碼的執行是由調用者用一種叫做gas的東西來支付的。Gas是運行以太坊虛擬機的燃料。你可以將其視為每次執行指令的費用(就像一行代碼)。
你需要為一個特定的合約調用設置可花費的最大gas。比如,如果你調用的代碼進入了一個永久循環,將會確保在執行過程中所花費的gas不會超過設置的最大gas。
gas(執行)的成本由網絡的礦工(運行代碼的節點)決定。關于gas和執行,還有很多知識。但以上這些值得牢牢記住。
智能合約如何工作?
當一個智能合約被部署到以太坊網絡時,任何人都可以調用智能合約的函數。雖然出于安全考慮該函數可能阻止人們調用,但你可以自由嘗試。
假設有一個MyObject類型的對象。該對象有一個名為myFunction的函數。要調用它,只需引用對象的實例、調用哪個函數和使用哪個參數調用。
像這樣:
myObjectReference.myFunction(parameters);
該函數返回的任意值,可以將其存在變量中:
myVariable=myObject.myFunction(parameters);
調用一個智能合約在概念上是一樣的。唯一的區別是,你必須將調用相關的所有信息放在交易中,對其簽名并發送到網絡上來執行。
假設你想要調用函數myFunction,其中包含智能合約“0x0123456”里的一些參數。調用智能合約分四步:
現在,當交易被放進區塊鏈中的一個塊,該狀態變化便會被記錄在整個網絡中。
世界計算機
許多人把以太坊稱為世界計算機。這是個不錯的類比。它就像一臺由整個世界來維護的虛擬機。
但是請記住:雖然智能合約是圖靈完備的,并且理論上可以做任何事情,但它們不太適合繁重的計算工作。
以太坊世界計算機就像一臺運行簡單程序的老式慢速計算機。由于成本和安全性,保持以太坊的智能合約小而簡單是至關重要的。
合約需要的計算量越多,運行的成本就越大。合約越復雜,就越有可能存在安全漏洞。而且智能合約中的安全漏洞是很難處理的——畢竟區塊鏈是不可變的。
舉例:通證
回歸重點,我想解釋一下通證是如何工作的。
大多數這些通證都是在以太坊上創建的,而且概念非常簡單。
如何使用Javascript或其他編程語言編寫一個簡單的貨幣系統?你可以在一個文件中完成所有的操作。你真正需要記錄的是:
1.總供應量
2.賬戶
3.賬戶中的余額
4.資金流向
通過用戶和余額之間的簡單映射,你可以得到123的答案:
該map只是把一個賬戶映射到一筆錢。
使用構造函數,你可以在自己的帳戶中設置初始供應量
資金的流動是通過簡單的函數來完成的,即從一個賬戶中減去,然后加在另一個賬戶上。
創建通證與我們在以太坊使用的概念完全相同。當然,還有一些更復雜和額外的功能,但是基本概念非常簡單。
以下就是基本的通證合約在以太坊編程語言中呈現的樣子(再次重申:為清晰起見進行了簡化):
這就是基礎編程概念。我認為這說明了以太坊作為一個平臺的力量。通過一些簡單的代碼,你可以憑空生成一個代幣,它本質上就是由世界計算機記錄的一些變量。歡迎來到新的互聯網。
------
風險警示:藍狐筆記所有文章都不構成投資推薦,投資有風險,投資應該考慮個人風險承受能力,建議對項目進行深入考察,慎重做好自己的投資決策。
通往區塊鏈的新世界:關注“藍狐筆記”公眾號:lanhubiji
加入藍狐筆記的知識星球:https://t.zsxq.com/iaQNnIq
加入藍狐筆記群微信:pacinoli
Tags:區塊鏈以太坊比特幣UNT區塊鏈工程專業學什么課程的以太坊幣今日價格行情美元比特幣走勢圖十年Greenheart Punt
白話區塊鏈 從入門到精通,看我就夠了!“教主,我感覺PoS共識機制好像漸漸要成為主流了”戰士難得的做了點思考,直接扔給我一個結論。“哦,這話怎么講呢?”我饒有興趣的看著他.
1900/1/1 0:00:00作者系MakerDAO中國區負責人潘超作為以太坊上基礎穩定貨幣的提供者,MakerDAO在兩個月內連續五次加息,借Dai利率從0.5%一路提高到14.5%,并預計升至16.5%.
1900/1/1 0:00:00尊敬的ZG.TOP用戶:ZG.TOP“搶購點卡送ZGT活動”已經全部順利完成!感謝所有用戶的參與以及對我們的信任和支持!對于用戶最關心的問題之一,點卡如何轉讓或交易,我們第一時間投入開發.
1900/1/1 0:00:00區塊鏈的世界里從來不缺熱鬧。正如當下BAT在互聯網格局中的三足鼎立,在相當長的一段時間里,數字貨幣交易平臺一直是幣安、OKEX、火幣“的局面.
1900/1/1 0:00:00Gate.io已上線“Startup上線通道”,為給優質初創項目提供更為快捷的上幣通道,和給予用戶提供早期投資機會.
1900/1/1 0:00:00關于AT AT以連接人與一切數字資產為使命,以打造伯克希爾式的通證經濟產融平臺為愿景,旗下擁有先知社群、先知伙伴、先知資本三大業務板塊.
1900/1/1 0:00:00