比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads

深入交易細節,理解以太坊智能合約的工作原理_區塊鏈

Author:

Time:1900/1/1 0:00:00

你可能聽說過「智能合約」,甚至可能知道它們是在區塊鏈上運行的代碼。但是你如何才能在區塊鏈上運行代碼?這不是可以輕易理解的簡單概念。本文解釋了智能合約是如何在以太坊區塊鏈上運行的。對編程的基礎理解將會有所幫助,因為本文包含了一些用于舉例的簡單代碼。為了清晰起見,本文將其中的一些技術細節稍微進行了簡化,但概念是有效的。

原文標題:《UnderstandingEthereumSmartContracts》

原文作者:GjermundBjaanes

翻譯:藍狐筆記社群Dyna

一、區塊鏈——快速入門

這里不講太多細節,區塊鏈技術的核心概念是分布式賬本。它是一種在眾多參與者之間共享的特殊類型的數據庫。

這個特殊的數據庫就是一個交易列表,記錄了網絡中發生的每一筆交易。每個人都有一個副本。這種去中心化分布結合強有力的貨幣激勵措施,消除了各方之間信任的必要性。

傳統意義上,當事人之間的信任是通過中間人,即第三方來解決的,比如Paypal、銀行。與你不信任的人之間的交易將通過雙方都信任的中間人進行。

有了區塊鏈,這種需求消失了。因為你可以把你的信任放在網絡上,在這里,強有力的激勵措施消除了作弊欺騙的欲望(簡而言之:遵守規則更有利可圖)。

Polygon Studios CEO:Polygon將于2023年深入參與PFP和藝術領域:12月27日消息,Polygon Studios 首席執行官 Ryan Wyatt 表示:2022 年 Polygon 與 OpenSea、Magic Eden、Coinbase、Robinhood 和 Phantom 建立或擴大了合作關系,并參與了游戲、DeFi 和音樂領域。Polygon 將在 2023 年深入參與 PFP 和藝術領域。[2022/12/28 22:11:26]

更具體地說:區塊鏈網絡是一組機器,它們記錄著相同的交易列表副本(例如,從A轉給B的錢)。

因為每個人都有相同的列表,所以很難欺騙網絡接受錯誤的交易。結合一些加密算法和貨幣獎勵以便遵守規則,你的網絡會非常安全。

所有這些也使得區塊鏈幾乎是不可變的,因為改變歷史記錄的唯一方法是獲得全網大多數人的同意。

二、什么是智能合約?

區別于比特幣,以太坊最大的不同是引入了智能合約的概念。比特幣是數字貨幣,以太坊也是數字貨幣,但遠不止這些。

「智能合約」這個名稱有點誤導人。它們不是真正的合約,也不特別智能。它們只是一些可以運行在區塊鏈上的代碼-或者說是計算機邏輯運算。

聲音 | 中國互金協會副秘書長:我國區塊鏈在金融領域應用總體處于早期嘗試向深入探索轉變的過渡階段:金色財經報道,11月20日,“金融進化論:2019新京報金融科技論壇”上,中國互金協會副秘書長楊農表示,當前,我國區塊鏈在金融領域應用,已在供應鏈金融、金融數據共享和金融信息存證等場景中形成了一些落地案例,總體處于早期嘗試向深入探索轉變的過渡階段,且呈現出探索性應用數量較多、參與主體較為多元、底層技術原創有待加強等特點。同時,區塊鏈在我國金融領域的應用探索也面臨著如下幾個方面的挑戰:技術層面仍難以兼顧部分金融應用場景對安全、功能和性能的要求;研發層面自主創新有待加強,對國外開源程序的廣泛應用可能導致技術依賴風險;業務層面部分金融應用環節尚存在模糊地帶,部分機構在開展區塊鏈應用創新時缺少權威的第三方評估意見作為參考;治理層面存在法律規制困難,如鏈上資產和智能合約等方面的法律有效性界定不清晰。[2019/11/22]

首先,我將介紹有關智能合約是以太坊網絡上的一種特殊賬戶。你有用戶賬戶,你還有智能合約賬戶。

一個用戶賬戶包括:

一個地址

余額

一個智能合約賬戶包括:

動態 | 南開大學新設金融科技研究中心 對區塊鏈等科研課題進行深入研究:7月13日,南開大學金融學院金融科技研究中心在天津成立。該中心內設南開大學金融學院金融科技創新實驗室,對金融以及人工智能、大數據、區塊鏈等科研課題進行深入研究,并推動與在金融科技領域全球領先的機構和專家廣泛合作,培養出優秀的研究人才和產業人才。[2018/7/13]

一個地址

余額

一個狀態

代碼

地址和普通賬戶的地址是一樣的,它是該賬戶的唯一識別符。

余額和普通賬戶也是一樣的概念。唯一令人激動的是,智能合約上的余額意味著代碼可以擁有金錢。它可以處理這些錢,也可能因為編碼錯誤而造成處理不當。

智能合約帳戶的狀態是智能合約中聲明的所有字段和變量的當前狀態。它的工作方式與大多數編程語言中類的字段變量相同。事實上,一個類的實體化對象可能是理解智能合約的最簡單方法。唯一的區別是這個對象是永久存在的(除非被編程為自我毀滅)。

智能合約的代碼是編譯好的字節代碼,以太坊客戶機和節點可以在上面運行。它是在創建智能合約時執行的代碼,并且包含可以調用的函數。就像面向對象編程的語言中的任何對象一樣。

天津市委網信辦會議:深入開展區塊鏈等領域的地方立法研究:天津日報6月8日報道,日前,天津市委網信辦召開全體干部會議。會議要求,要加快制定天津市大數據發展規劃和促進數字經濟發展的指導意見和大數據發展規劃,深入開展大數據、區塊鏈等新技術領域的地方立法研究,不斷增強工作的前瞻性。[2018/6/8]

關于智能合約的趣事:它們可以調用其它的智能合約。這就開啟了創建自主代理的能力,這些代理可以自己花錢和進行交易。

假設我用上面的代碼創建了一個智能合約。該代碼有一個名為counter的字段,類型為uint(整數)。counter變量的內容是本合約的狀態。每當我調用count()函數時,任何人都能看到這個智能合約在區塊鏈上的狀態將會加1。

稍后我們將通過更多的例子來解釋它是如何工作的,但首先我想回到以太坊和比特幣的交易,并以此來解釋一些事情。

三、交易水平上,以太坊VS比特幣

比特幣交易非常簡單。你可以只做一件事。一種類型的交易。略過一些細節,一切都可以歸結為TO,FROM和AMOUNT。這使得比特幣成為一種價值儲存手段,能夠在網絡參與者之間傳遞價值。

以太坊的不同之處在于交易還有一個「DATA」字段。該「DATA」字段支持三種類型的交易:

迅雷CEO陳磊:區塊鏈一定要深入到老百姓當中:迅雷CEO陳磊在接受媒體采訪時表示,“區塊鏈一定要深入到老百姓當中。區塊鏈的發展還在一個相對早期的階段,所以一旦你掌握了區塊鏈的一些正在改進中的技術,那么就能取得領先,但是這些技術必須要和現實場景結合才能有意義。我們希望看到,迅雷生態鏈上能有大量推動實體經濟發展和C端用戶參與的應用,這是區塊鏈發展的核心動力。”[2018/5/20]

價值轉移

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

調用一個智能合約在概念上是一樣的。唯一的區別是,你必須將調用相關的所有信息放在交易中,對其簽名并發送到網絡上來執行。

假設你想要調用函數myFunction,其中包含智能合約「0x0123456」里的一些參數。調用智能合約分四步:

現在,當交易被放進區塊鏈中的一個塊,該狀態變化便會被記錄在整個網絡中。

六、世界計算機

許多人把以太坊稱為世界計算機。這是個不錯的類比。它就像一臺由整個世界來維護的虛擬機。

但是請記住:雖然智能合約是圖靈完備的,并且理論上可以做任何事情,但它們不太適合繁重的計算工作。

以太坊世界計算機就像一臺運行簡單程序的老式慢速計算機。由于成本和安全性,保持以太坊的智能合約小而簡單是至關重要的。

合約需要的計算量越多,運行的成本就越大。合約越復雜,就越有可能存在安全漏洞。而且智能合約中的安全漏洞是很難處理的——畢竟區塊鏈是不可變的。

舉例:通證

回歸重點,我想解釋一下通證是如何工作的。

大多數這些通證都是在以太坊上創建的,而且概念非常簡單。

如何使用Javascript或其他編程語言編寫一個簡單的貨幣系統?你可以在一個文件中完成所有的操作。你真正需要記錄的是:

總供應量

賬戶

賬戶中的余額

資金流向

通過用戶和余額之間的簡單映射,你可以得到123的答案:

該map只是把一個賬戶映射到一筆錢。

使用構造函數,你可以在自己的帳戶中設置初始供應量

資金的流動是通過簡單的函數來完成的,即從一個賬戶中減去,然后加在另一個賬戶上。

創建通證與我們在以太坊使用的概念完全相同。當然,還有一些更復雜和額外的功能,但是基本概念非常簡單。

以下就是基本的通證合約在以太坊編程語言中呈現的樣子(再次重申:為清晰起見進行了簡化):

這就是基礎編程概念。我認為這說明了以太坊作為一個平臺的力量。通過一些簡單的代碼,你可以憑空生成一個代幣,它本質上就是由世界計算機記錄的一些變量。歡迎來到新的互聯網。

來源鏈接:www.gjermundbjaanes.com

Tags:區塊鏈以太坊GASDAT藝術幣區塊鏈以太坊幣價格今日行情價格UGAS價格Crypto Makers Foundation

幣安app官網下載
關于調整交易對價格精度的公告(二)_數字貨幣

親愛的社區用戶: 為優化幣幣交易體驗,我們計劃對交易對最小精度進行調整,FCoin將于2019年04月29日16:00(GMT8)調整交易對價格精度.

1900/1/1 0:00:00
Binance開放ENJ/USDT交易市場_BIN

親愛的用戶: Binance將于2019年04月18日中午12:00上線ENJ/USDT交易市場,邀您體驗!風險提示:數字貨幣是一種高風險的投資方式,請投資者謹慎購買,并注意投資風險.

1900/1/1 0:00:00
JEX上線周NEO期權0507公告_SDT

NEO看漲期權 代碼周NEO看漲0507期權標的NEO合約類型歐式看漲期權計價單位USDT最小價格單位0.0001USDT合約比例1:1.

1900/1/1 0:00:00
BALIC 上線預告_ANC

親愛的Bit-Z用戶: Bit-Z將于近期上線BALIC,敬請期待。具體上線時間請留意后續官方公告.

1900/1/1 0:00:00
剖析新一輪全球金融危機_COI

本文由BitMEX研究團隊提供摘要:我們探討的是加密貨幣圈內人士經常提起的一個問題:“新一輪全球金融危機何時來臨?”我們試著回答這個問題,首先要解釋的是,2008年之后.

1900/1/1 0:00:00
2019,最深的谷底,也是最大的機遇!_HPT

2019最深的谷底,最大的機遇來自幣市小姐姐00:0020:39跌宕的2018年,幣圈在瘋狂中開始,在落寞中結束.

1900/1/1 0:00:00
ads