1
区块链
区块链技术发展到现在,一般认为经历了三个阶段,即以比特币为代表的第一阶段,以太坊为代表的第二阶段和以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机制,更灵活方便一些。
现在还出现了智能预言机,可以在不同的条件下自动的灵活的实施智能合约。
六、总结
智能合约和预言机相辅助相成,一定会在区块链技术的发展中不断的壮大起来,最终实现自然世界和区块链世界的数据自然高效的流转。
全部0条评论
快来发表一下你的评论吧 !