智慧合約和預言機初探

買賣虛擬貨幣

區塊鏈技術發展到現在,一般認為經歷了三個階段,即以比特幣為代表的第一階段,以太坊為代表的第二階段和以EOS為發展方向的第三階段。

一、 智慧合約從以太坊開始,智慧合約開始登上歷史舞臺,然後各種可執行智慧合約的區塊鏈紛紛出現,從最初的以太坊實現了智慧合約的功能,到INT中的智慧合約有擴充套件區塊鏈智慧合同TX的能力 (稱作INT Contract)。進而小蟻的NeoContract從開發的方便易用下手,支援多種語言,如C#,C++等。還有的比如Asch,拆分開不同的合約叫做令牌系統或者仲裁合約。等等,不一而足。

以太坊的智慧合約在區塊鏈中的位置如下圖:

其實也就是說,智慧合約已經在區塊鏈中佔有了重要的一席之地。

要很好的理解智慧合約,其實是要了解虛擬機器的,比如以太坊的EVM,EOS的WASM等。這些類似於JAVA虛擬機器(這個不恰當,但容易理解,事實上前者要簡單的多)把一些程式碼執行起來,不管是解釋的還是編譯的,亦或者二者兼而有之的。

虛擬機器從最初的只執行一些簡單的指令到後來的執行二進位制資料,逐漸走向成熟。相伴隨的,智慧合約也就越來越強大,易用。

二、智慧合約的例子

1、比特幣的指令碼(類智慧合約)

為什麼叫類智慧合約呢,其實比特幣是沒有智慧合約的,只有指令碼,它只是使用一些簡單的指令來完成特定的功能,下面是比特幣一個指令碼的說明:

2、以太坊智慧合約

以太坊的智慧合約就比較接近於流行的程式語言了,而且它也有自己的IDE,browser-solidity,可以輕鬆的編寫和除錯智慧合約:

contract TestStore {
uint sData;
function setData(uint d) {
sData = d;
}
function getData() constant returns (uint) {
return sData;
}
}
這個合約只是儲存並讀取一個資料,但是卻比比特幣的指令碼前進了一大步。3、EOS智慧合約
首先看一個入門的智慧合約hello world.
class hello :public eosio::contract
{
public:using contract::contract;
/// @abi action
void helloworld( account_name user )
{
print( "Hello world, ", name{user} );
}
};
EOSIO_ABI( hello, (helloworld) )
你會發現EOS的智慧合約已經完全是和主流的開發語言保持一致了。三、智慧合約的編譯智慧合約的編譯在不同的時期有不同的處理方式,相信在以後也還會有更大的進步。早期的比特幣中只是將指令碼按字串拆分即可,沒有什麼獨特的地方,更談不上編譯步驟。而到了以太坊就出現了獨立的程式語言Solidity和編譯器,只有使用編譯器編譯好以後才可以執行在EVM虛擬機器中。
而到了EOS,就更是強大到了使用CLANG+LLVM生成Webassembly位元組碼格式。這就意味著可以使用非常強大的主流的編譯器和通用的編譯方法。使得EOS的編譯器可以編譯出更安全健壯的可執行的智慧合約。四、智慧合約的執行比特幣的指令碼執行非常之簡單,只不過是呼叫函式來進行字串的分析即可,依據不同的標記來解析出相應的指令,再依據相應的指令進行功能的驗證和執行,這樣最終達到指令碼執行的目的。以太坊的智慧合約的執行,則需要先利用SOLC智慧合約編譯器將程式碼編譯成EVM位元組碼,然後將EVM位元組碼透過Geth的RPC介面傳送到以太坊網路,驗證執行。EOS的智慧合約則需要透過JIT將.wast轉成.wasm檔案,並且輔助一個abi的檔案。二者共同將智慧合約佈署到虛擬機器上,由虛擬機器執行。五、預言機(Oracle)
預言機是區塊鏈和自然世界的介面,目前是區塊鏈技術發展的一個方向。對於智慧合約來講,預言機就是智慧合約的輸入引數。而大家都知道,智慧合約是無法離開引數的輸入的。而引數直接影響到了智慧合約的最終的輸出結果。舉一個例子,預測世界盃的比賽結果,依賴於關鍵節點的資料輸入,如果有人惡意的輸入錯誤的結果,那麼,智慧合約依據這個錯誤的結果一定會輸出錯誤的結論。因此,預言機對輸入引數的依賴性是強相關的。預言機可以分為以下幾種型別:1.軟體提供資料的預言機這種預言機很好理解,類似上面的例子,輸入的引數需要一些網站或者相關服務商來得到。2.硬體提供資料的預言機
主要是物聯網行業,大量的資料可以從硬體採集器或者說相關的感測器採集併傳送上來。3.可信共識預言機主要是為了解決輸入引數的可信性問題,可以不使用單一的資料來源,比如從多個資料點採集資料,並依據共識原則達到最終的引數採集輸入。Oracle現在開始陸續在各個區塊鏈上有所展現。在以太坊的內部有一些簡單的預言機,後來又出現了第三方的以太坊的Oraclize,提供了與外界互動的強大能力。國內的ONT的混合預言機(HydraDAO),另外量子鏈(QTUM)的Oracle增強了DataFeeds機制,更靈活方便一些。現在還出現了智慧預言機,可以在不同的條件下自動的靈活的實施智慧合約。六、總結
智慧合約和預言機相輔助相成,一定會在區塊鏈技術的發展中不斷的壯大起來,最終實現自然世界和區塊鏈世界的資料自然高效的流轉。


來源:公眾號(360區塊鏈實驗室

更多區塊鏈資訊:www.qukuaiwang.com.cn/news

免責聲明:

  1. 本文版權歸原作者所有,僅代表作者本人觀點,不代表鏈報觀點或立場。
  2. 如發現文章、圖片等侵權行爲,侵權責任將由作者本人承擔。
  3. 鏈報僅提供相關項目信息,不構成任何投資建議

推荐阅读

;