智能合约是一个区块链项目的核心。但是这是什么呢 它能解决哪些问题呢?
就我们目前对于区块链的讨论而言,我们已经说过很多话题,包括什么使得区块链转账不可篡改,区块链技术是如何在多方金融交易中提供信任等等。但是我们还没有说过,区块链技术如何去中心化的,这就是“智能合约”的内容。
在我们深入研究这个话题之前,首先需要说明,除了名字,智能合约并不是传统意义上的合约,它也不能代替合约。智能合约是一套软件程序,是基于区块链的,并且会在区块链检测到某些特定数据条件下时会触发。如果这个听起来很模糊,这是因为智能合约可以在很多场合应用。
智能合约:概念、特征与应用
正式介绍智能合约之前,先来说说当前存在的最有影响力的两大公链,即比特币和以太坊。前者作为区块链1.0版本的代表,区块加载的账本信息比较单一,集中于认证新币产生以及旧币在账户间转移,并无其他更多功能。而后者作为区块链2.0版本的代表,更重要的是想要创建一种操作系统式的生态,人们可以利用该生态实现更多样化的价值创造与转移,而其核心工具就是所谓的“智能合约”。以太坊上也存在数字货币,但以太币主要是用于支付智能合约的相关运算,其存在的意义和比特币有着重大差别。
什么是智能合约?
视频里也讲到,智能合约是由尼克萨博在1996年首次提出的概念。更确切的说,它是出现在比特币时代之前的,他对智能合约的定义如下:
一个智能合约是一套以数字形式定义的约定,包括合约参与方可以在上面执行这些约定的协议。智能合约的基本思想是,各种各样的合约条款可以嵌入到我们使用的硬件和软件中从而使得攻击者需要很大的代价去攻击。
因此,尼克萨博设想了一种能够自动执行的智能合约,而且攻击它的代价是昂贵的。很显然,当区块链出现的时候,人们就已经开始了努力尝试用区块链来实现这种可自动执行且攻击代价昂贵的智能合约。毕竟,PoW共识算法之下回溯更改区块中的一笔交易,代价是巨大的;而且可以提供自动执行的审查交易进入以太坊等。他们保证了图灵完备性,意味着什么都可以执行。
而智能合约的原型,就类似于自动售货机,通过一系列的设计实现共识并予以执行。具体而言,智能合约是条款以计算机语言而非日常语言或法律语言记录的智能合同,其工作的基本原理类似于计算机程序的if-then语句,在预先设定的条件达成时,就自动执行相应的合同条款。
所有这些新的智能合约的平台,为用户提供了一个新的去中心化的世界:编写和执行从不停止的代码成为可能,这就导致了未来各种各样的创新,比如“去中心化的优步”、“去中心化的爱彼迎”以及“去中心化的黑暗网络市场”。或者更进一步来讲:去中心化的计算。以太坊试图成为“世界的计算机”。
智能合约要实现其“在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转”的功能,现在看起来必须和区块链技术结合在一起。一方面,区块链的结构特点决定了智能合约的内容(代码)可追踪且不可篡改,另一方面,区块链上能够加载的丰富资源和价值,使得各种合约的自动执行成为可能。
智能合约工作原理
基于区块链的智能合约构建及执行分为如下几步:
1、多方用户共同参与制定一份智能合约;
2、合约通过P2P网络扩散并存入区块链;
3、区块链构建的智能合约自动执行。
多方用户共同参与制定一份智能合约”的过程,包括如下步骤:
(1)首先用户必须先注册成为区块链的用户,区块链返回给用户一对公钥和私钥;公钥做为用户在区块链上的账户地址,私钥做为操作该账户的唯一钥匙。
(2)两个以两个以上的用户根据需要,共同商定了一份承诺,承诺中包含了双方的权利和义务;这些权利和义务以电子化的方式,编程机器语言;参与者分别用各自私钥进行签名;以确保合约的有效性。
(3)签名后的智能合约,将会根据其中的承诺内容,传入区块链网络中。
合约通过P2P网络扩散并存入区块链”的过程,包括如下步骤:
(1)合约通过P2P的方式在区块链全网中扩散,每个节点都会收到一份;区块链中的验证节点会将收到的合约先保存到内存中,等待新一轮的共识时间,触发对该份合约的共识和处理。
(2)共识时间到了,验证节点会把最近一段时间内保存的所有合约,一起打包成一个合约集合(set),并算出这个合约集合的Hash值,最后将这个合约集合的Hash值组装成一个区块结构,扩散到全网;其它验证节点收到这个区块结构后,会把里面包含的合约集合的Hash取出来,与自己保存的合约集合进行比较;同时发送一份自己认可的合约集合给其它的验证节点;通过这种多轮的发送和比较;所有的验证节点最终在规定的时间内对最新的合约集合达成一致。
(3)最新达成的合约集合会以区块的形式扩散到全网,如下图所示,每个区块包含以下信息:当前区块的Hash值、前一区块的Hash值、达成共识时的时间戳、以及其它描述信息;同时区块链最重要的信息是带有一组已经达成共识的合约集;收到合约集的节点,都会对每条合约进行验证,验证通过的合约才回最终写入区块链中,验证的内容主要是合约参与者的私钥签名是否与账户匹配。
智能合约与传统合约相比,个人认为最大的特点和优势就是其解决了“信用”的问题。传统合约达成前,参与者先要了解各方的信用背景以选择合适的对象,合约达成后的阶段,也要依赖于各方的诚实信用,或者引入第三方(如支付宝)来担保合约履行。但在智能合约的场合,链上的资源是真实透明的,合约的内容确定后就无法更改,执行更是不用依赖任何额外操作。最终,“匿名信用”成为现实,合约缔结前无需进行信用调查,缔结后也不用第三方进行担保履行,从而实现交易成本大大降低,交易效率则大幅提高。虽然现阶段的智能合约还存在安全性不够充分,私密性难以保障,上链资源受限等种种问题,但从理论上说,其应用前景无疑是广泛的,在不断完善改良之后,代替很大一部分传统合同以及创造出一批新型合同,这都是很有可能的。
三、相关法律问题
智能合约的应用场景是广阔的,但随之而来的法律问题也可能是多方面的。由于其主流应用在当前还并未成为现实,所以此处所谓法律问题的探讨,与其说是分析问题和解决问题,不如说是发现问题,甚至是想象可能存在的问题更为贴切。
1、资源上链的基础问题:
智能合约的性质是合同,表达的是一种债权关系。根据民法原理,债权关系得以成立的基础,是物权关系的存在。如何使得更多资源上链,也就是建立基于区块链的物权体系,恐怕是决定智能合约应用范围的基本前提。好消息是,那些没有实体而本身就需要登记的财产权,如公司股权、知识产权等,正是区块链技术应用的前沿阵地,有望早于其他财产权提前上链,从而围绕这些资源就有更大余地去设计相关的智能合约。但日常生活中涉及的其他资源要如何代码化,如何同现有法律体系下的物权体系相对接,恐怕是一个必须同时从技术和法律两个角度来考虑并设计的问题。
2、智能合约与法律文本之对应关系:
智能合约全部由代码组成,而典型的合同则是一份有着法律意义的文本,这两者之间存在到底能否对应以及如何对应的问题。一方面,通过智能合约的订立和自动执行,完全有可能实现和传统合同一样的法律效果,因此理论上可以将代码“翻译”为法律文本,或者至少在一定程度上解读出双方合意。另一方面,智能合约无疑又缺乏很多传统文本所含有的要素,比如在匿名的环境中,签约主体的身份首先就不明确。代码能否“翻译”,可能是智能合约接受合同法规制的现实基础。
3、合约无法更改的两面性:
智能合约的最大特点就是无法更改和自动执行,这构成了智能合约实现“匿名信用”的基础。但合约无法更改显然具有另外一方面的安全隐患。传统合同的语境下,合同存在无效或者可撤销、可解除的情形,都可能导致合同履行的终止。然而在智能合约的场合,这些机制还有适用的可能吗?如果要继续适用,在一个去中心化的环境中,需要引入怎样的技术手段才能得以实现?如果合同履行能够被终止,那么智能合约的基础就可能被动摇,考虑到这一点,是否要坚持“代码即法律”,将智能合约的自动执行贯彻到底?这些问题都无法简单得以回答。
4、对传统合同法理念的各种挑战:
区块链和智能合约是具有“解构”性质的新技术,其应用对传统合同法的理念和基本框架将带来冲击。在智能合约的语境下,不需要什么“诚实信用”,不需要什么“合同的履行”甚至在合约全部能够自动执行的情况下,连平时被大家倒背如流的“违约责任”这一章都显得多余。对智能合约到底应该怎样适用合同法规范,智能合约又将如何改造现有的合同法规范,在将来一段时间内恐怕会成为法律人们不得不面对的课题。
问题1 :现实资产
但是当很多人阅读尼克萨博的文章时,很明显的感觉到,尼克萨博对“为了把现实世界中的资产和行为与智能合约联系起来,可信人和公证人是需要的”是非常清楚的。你不能把强迫一个人去使用区块链来把他的车通过软件来交给他。你不能强迫一个人使用区块链根据软件定义规范来创建一个特定的应用程序。你不能强迫你的毒贩来用区块链来发给你那些你已经支付的大麻。这是不可能的。在这些情况下,显然需要一名仲裁员。交易的双方都需要信任第三方,如果双方都不同意那么就需要它来进行仲裁。
在这些情况下,当现实世界的资产或服务转化成数字货币时,很明显“智能合约”不能增加很多,他们唯一能做的就是为联合账户提供理论。在大多数情况下,这就是一个简单的“2/3的多重签名”:买方、卖方和受信的第三方创建一个联合账户。当买方收到货物时,他会签署交易,卖方收到钱时,也会签署交易。如果买方不想签署交易,因为他认为产品不好或者服务不到位,受信的第三方就可以进行仲裁,如果他认为合适的话,可以退还买方(部分)金额。如果卖方可以证明他确实做到了事前已达成协议,仲裁员可以决定绕过买方并把钱寄给卖方。
但是,等等,我们是要干什么来着?这难道不可能在比特币上持续几年吗?是的,这意味着整个用例在比特币上是可能的。那这样看来,以太坊以及其他的智能合约平台没有添加任何有用的东西。区块链看起来并不需要一个图灵完备的平台。
问题2:可信节点
那运行网站或者相关平台呢?现实世界中没有任何资产应用到这些项目中。当然,这不仅仅是货币交易对吧?好吧,我们这样想,我们想在以太坊这种世界计算机上运行一个网站,这样这个网站就能“永不停歇”。这听起来相当模糊。它在实际中意味着什么呢?网站的创建者把网站的代码放到区块链上,所有的节点都下载代码,打开网站。如果每一个节点都需要下载所有的网站,这将会造成巨大的带宽和存储消耗。这看起来非常的低效。如果你不需要这个网站,那你为什么还为了它而下载所有的代码?通常来讲,用户只从网站服务器上下载他们需要的文件,并在浏览器中打开它。“图灵完备的智能平台”所尝试的是另一种方式。
好吧,我们假设只有某些节点下载了所有网站的内容,其他节点只下载了部分的内容。我们现在部署的是一种分布式的服务器,任意一个用户都可以连接到它并获得网站。用户本身不会运行一个全节点来连接到他们自己版本的网站。但是,运行一个全节点的动机是什么呢?你只能通过执行代码来获得奖励,而不是通过存储和广播大量的数据。比方说,智能合约平台编写了一个合约,让用户为每一次发向节点的数据请求进行支付。(请注意,这也需要所谓的分片,因为当只有某些特定的节点可以对请求数据应答时,也只有这些节点就可以对智能合约验证有效性。)用户是如何确定他得到的是一个正确的而不是低级甚至是错误虚假的版本?除非用户使用原始服务验证数据,否则无法解决此问题。所以用户要么盲目的信任他连接到的节点,要么他就连接到在区块链上发布网站的原始节点。那么我们又回到了一开始很明显,连接到为网站服务的中心服务器上是更加有效的。如果你想要拥有一个永不停歇的网站,那么就把它当做一个在Tor或I2P网络上运行的隐藏服务不需要巨大的带宽和极大地存储代价,不需要信任其他节点,不需要支付访问人们往往会忘记,互联网本身就是相当的去中心化的。如果你运行自己的服务器,那么你就是以去中心化的方式来运行你的网站的。然而,为网站申请一个托管公司却是更有效更可靠的。
问题3:数据服务
这就带给了我们预言机(Oracle)的概念。预言机基本上是一个提供数据的可信服务。与被用作网站服务器的非全节点相比,这是一个不太激进的想法,因为预言机唯一的目的就是为智能合约提供一份独特的输入数据。想象一下,在欧元兑美元汇率上有两个选项。你可以打赌,到今年年底欧元将跌至1美元以下。智能合约可以处理一切。所有的代码都在区块链上运行的:你在合约地址中存入一定金额,当智能合约检测到一欧元确实低于一美元时,合约就会执行,然后你就会双倍的拿回你的钱。若果今年年底,欧元并没有跌至1美元以下,你就输了,你的钱就会被拿走。
这看起来非常直接,非常容易实现,对吧?不过有个小问题……智能合约从哪里得到支持它检查欧元和美元汇率的实时数据?这些数据区块链上是没有的,而是存在外部的。你可以使用例如这个链接中的免费的API来跟踪欧元和美元的汇率,并且把它编码到智能合约中。但是仍然有一个很大的问题……当外部数据源崩溃时,会显示0为欧元和美元兑换汇率,这时会发生什么?智能合约是可以自动执行的。交易是有效的而且是不可变更的。所以这两个选项的创建者因为数据源中的bug而丢失了钱。你可以使用不同的数据源来提供数据并忽略异常值。例如,你使用了3个实时更新的数据源,那么智能合约会自动忽略离平均值最远的那个,并根据剩下的两个数据重新计算平均值。这似乎已经解决了问题。如果有异常值,也不会影响智能合约要用的数据的。但是弱点依旧存在。如果已经到了12月31号,欧元兑美元的汇率仍然没有下降到1美元以下,那么你将要损失1000万美元。那么你现在就有一个非常大的动机去贿赂其中的两条数据源:显示一分钟的0.9美元作为汇率,为此你支付他们200万。结果呢,你会赌赢,并且获利2000万!而且数据源拥有者也可以自己创建投注,并故意在他们的软件中创建漏洞,从中获利。
很显然区块链并没有解决这种问题,并且使它变得更糟。NADAQ上的错误数据资料可以通过回滚一些交易来修正,但区块链上的智能合约是无法回滚的(除非您是Vitalik Buterin的朋友)。我希望你现在明白为什么我对这个可信任的数据整个概念持有怀疑的态度。如果赌注不多的时候你可以信任一个数据源。即使发生错误你也只是损失少量的资金。如果你信任你的交易对手,并且他是一个诚实节点的话,你甚至可能拿回你的钱。但是,我非常确信,那些处理大笔交易的大公司是不会相信外部数据源的。他们会要求交易签名。是的,我们确实回到了交易中可信的第三方。
如果你不信任外部数据,那么我们能不能仅仅用一个多方签名的交易来决定到底是谁赢了赌注?实现是非常简单的:你在服务器上运行一个“智能脚本”。这个服务器把外部数据作为输入,来决定何时触发一个发送给仲裁员的警报。仲裁员会手动检查数据是否确实正确,如果是正确的,那么它就会对交易进行签名。如果仲裁员确定了这笔数据是错误的,那么你就可以起诉他并把你的钱拿回来。所以外部数据提供者就有提供正确数据的动机。这个系统也是非常有效的,因为区块链不需要检查每一个智能合约,它只需要验证多重签名交易的有效性。一切都发生在链上。我不会冒昧的构建“去中心化的外部数据”的“创新”。我非常确定那些也是可以玩的,但这就超出了本文的范围。
问题4:扩展性
仍然不相信“从不停止的代码”没有真正的用例? 我将提供另一个不需要信任的数据的例子。可以想象一个赌博的“dapp”(去中心化的应用),其中前一个块的哈希值被用作随机数生成器。你可以赌哈希是偶数或奇数。业主用一大笔钱资助了这个智能合约。赌徒提前下注给智能合约,并投注“偶”。如果哈希确实是偶数,那么他会得到1.98倍的赌注。当哈希值是奇数的时候,他什么也得不到,所以庄家上风是1%。这些都是可以编码和自动执行的。网站是没必要用这些的,所有这一切可以在块链上完成。 通常,您将为客户提供(集中式的,哈哈)网站作为GUI,但不是必需的。问题是:所有这些赌博交易数据仍然需要流经整个以太坊网络。每个节点需要检查用户发起的所有博弈。
在过去,中本聪曾经以类似的方式在比特币网络上运作。你可以向固定的博弈地址发送交易,如果你赢了,网站将自动把钱返回来。但是……你需要信任这个网站,相信它诚实地行事。理论上他们可以在拿到你的钱来运行。这就是以太坊的优势吧!等等等,不会那么快。 Satoshi dice 曾经是一个“链上”的服务,但它不再是了。猜猜这是为什么?答案很简单:拥堵。所有这些小额交易都需要被所有节点存储和转发。在早期的比特币没有被用得太多的时候,这些小额交易就有足够的区块空间。但是,目前交易费是如此之高,以至于小额交易不可能再很容易的被包含到区块中。因此,中本聪转为了一种中心化的模式:您首先在网站上投放比特币,然后才能开始下注。当完成后,你可以对币提现。与去中心化模型相比,这样做更有效率。我们曾经这样设想过,也这样做过。这很有趣,但长期来看,由于网络健康这是不可持续的。所以我们不这样做,以太坊也没有添加任何有用的东西。顺便说一下,由于网络拥塞,Etherdice目前是无法使用的。
问题5:挖矿动机
回到前面的例子,除了可扩展性,还有第二个问题:矿工们可以操纵块的哈希散列。他们可以下注,然后只发布拥有他们所需要的哈希值的块。实际上,这可能就是为什么Etherdice 使用外部数据(可能是random.org)来获得随机性的原因:
唯一的外部依赖是随机性的来源,因为区块链的确定性的本质使它难以通过安全的方式获得随机数据。
那么,如果即使是一个简单的博弈“智能合约”都不能依赖区块链,那么大公司怎么会用这个技术来创造重要且复杂的智能合约呢?
需要另一个例子? 我从以太坊挖矿社区那里听到了一个故事:在进行众筹的时候,为了不错过非常好的“投资机会”,投资者会相互竞争,尽快的把交易放到区块中。一些矿工通过一些侧面的渠道把交易包含到区块中来获得报酬。这些矿工拒绝其他交易。或者他们自己购买整个众筹,并且排出其他的投资者。所以挖矿的激励机制可能会矿工审查机构来获利。
还需要另一个例子?目前,一个去中心化的交互尚未实现。但是想象一下,一个矿工能够在去中心化的交易所上审查确定的买卖指令,并且能用自己的交易来运行它?它会第一个倾销这个代币,因而它也能在价格崩盘之前退出。这一切都是可能的。
所以,恕我直言,智能合约在区块链上是不安全的,那么你在外部服务器上就需要一个仲裁员和一段智能脚本,以可靠、可扩展的高效的方式来完成这些事情。
只是承载资产
那么我们剩下的就是,智能合约只用链上的数据、不依赖区块哈希值的随机性、也不依赖于执行的顺序。保存到区块链中的数据是非常有限的:包括交易数据、区块哈希和时间戳而已。所以这些“智能合约”实际上就是“传统的合同”。它们做不了其他任何更有用的事情。
目前,区块链唯一的价值加密数字货币。因为真实世界中资产并不是数字化的,所以把它们存储到区块链上是不可能的。数字货币就是一种所谓的“现实资产的承载货币”。它的价值就是代币本身。你不需要信任一个外部平台。当你转移代币时,你转移的就是价值。现在有一种可以扩展智能合约的方式:创造新的承载资产。
目前这种情况发生的频率很高,以太坊上众筹的项目的数目是惊人的。这些代币代表了它们本身的价值。它们大部分需要信任一个基础的平台,因为代币将会收到作为股息的利润。但是,代币仍然保持着预期的价值,并应能反映对平台的信任和获得股息的机会。那么众筹确实是智能合约的一个自然而然的应用。人们可以创建一个拥有收入来源的平台,而且利润自动分配给代币持有者,并且不会受到开发商的干扰。这是智能合约的一个潜在用例,但是可能会遇到像我们在satoshi dice 中看到的低效。它没有扩展性。如果平台的拥有者或者开发商是人工进行股息支付的,那使用一个“图灵完备的智能合约”也没有任何优势了。这是可以通过彩色币(Color Coin)的协议来完成的,没必要用以太坊。还要考虑这些众筹潜在的法律风险,根据法律政令他们中的大部分都是要关闭的。剩下的就是一些不三不四的“去中心化公司”(黑暗网络市场),向他们投资本身就是一种风险。
现在有一种更有趣的承载资产的类型:加密法币。如果政府决定在区块链上发行一个法币,那么代币就可以代表它本身的价值。在这种情况下,更有趣的是理论上智能合约将会成为可能。如果你能创建一个去中心化的交易所,理论上你可以得到区块链上数据交换的频率,并消除对外部数据存储的需求。但是就像我们看到的一样,区块链无法安全的实现链上交易。而且再次声明,区块链是非常低效的,任何大规模的交易都是不可能的。这一切虽然听起来不错,但实际上目前是不可行的。
图灵完备性增加了更多的风险,而不是利益
所以在我看来,区块链对智能合约来说并不是很有用。(非常有限的)附加福利是不值得的,因为我们同样需要考虑风险。事实就是,用图灵完备的平台来构建安全的应用是非常困难的。DAO的惨败已经让我们意识到了这件事情。我宁愿相信一个专注于钱的问题的区块链,也不愿在区块链上尝试智能合约,在大多数情况下,这根本没有什么利益可言,而且会面临更大的风险。
所以智能合约是可能的
但是也只是在非常具体的情况下。可扩展性问题使得它并不能被广泛的应用。在区块链上唯一能用的智能合约是易于计算的合约,不需要太大的存储能力和带宽,而且不是经常执行。所以在实践中,它只适用于大型交易。在区块链上用智能合约来执行大量的小额交易在经济上是不可行的。如果你仍然希望扩大交易量,则需要在外部服务器上运行“智能脚本”,并定期向区块链进行结算。如果你使用外部数据的话,智能合约也会有风险。所以最好是在区块链上使用多重签名,并且在外部服务器上运行一段智能脚本。如果你不想用外部数据,那么你就仅限于持有链上的无形资产,这跟传统合约也没什么两样。
让我们通过一个例子看看智能合约是怎么运行的。也许你熟知大型众筹平台Kickstarter,产品团队可以在Kickstarter 创建项目、设定资金目标,进而从那些相信这个想法的人那里筹集资金。
Kickstarter实质上是介于产品团队和支持者之间的第三方。这意味着双方都需要信任Kickstarter能够妥善地处理他们的资金。
如果项目成功获得筹资,项目团队希望从Kickstarter获得他们的资金。另一方面,支持者希望筹资后他们的资金能够给到项目,或者在没有达到目标的情况下获得退款。产品团队以及其支持者都需要信任Kickstarter。
但是有了智能合约,我们能够构建类似的系统,而不需要信任如Kickstarter这样的第三方。
那么让我们试着来构建智能合约
我们制定智能合约,它能持有所有收到的资金直到达到某个目标。现在项目的支持者可以把资金转到智能合约,如果项目获得足够的资金,智能合约自动将钱转交给项目的创建者;如果项目没能实现集资目标,钱会自动退还给项目支持者。
因为智能合约存储在区块链上,一切都是完全分布式的。有了这项技术,没人能控制当中的钱。
但是我们为什么要信任智能合约呢?
不可变和分布式
因为智能合约存储在区块链上,它们继承了一些有趣的特性。它们是不可变的、分布式的。不可变意味着一旦智能合约被创建,这永远都无法改变。因此,没有人可以背着你篡改合同的代码。分布式意味着,你合约的输出被网络上的每个人验证。因此,个人不能强迫智能合约放出资金。
因为网络上的其他人会发现这个举动并将其标记为无效。篡改智能合约几乎是不可能的。因此,以太坊从创始之初就并非以创造或者炒作某种加密货币为目的,而是致力于成为一个通用的、提供超强图灵完备脚本语言的优秀底层协议,从而极大地拓展了区块链的功能,使其可以管理金融和非金融类型的应用,而不是止步于加密货币。基于以太坊的智能合约使用户可以很方便地构建复杂的电子资产、消费模式等各种去中心化的应用。
智能合约技术是区块链应用中最主要的特征,也是区块链被称为颠覆性技术的主要原因 。智能合约可以帮助实现可编程货币和金融功能,提高自动化交易水平和交易效率,降低金融交易及合约执行成本,便于交易行为的管理,因此得到国内外金融机构和央行的关注。
未来,区块链的应用可能更多是向智能合约的方向发展,并对数字货币和其他金融领域产生重大影响 。但需要指出的是,区块链是技术手段,尽管它对比特币的形成和发展发挥了重要作用,但技术本身是中性的,并不构成对比特币正当性和科技创新性的背书。
以区块链技术来划分“古典互联网”与“现代互联网”的说法已经开始在网络上流传。相较欧美各国区块链技术应用的大踏步迈进,在谨慎金融观指导下的当今中国,许多应用看起来难免有“过家家”之嫌。
但这又何妨呢,既然技术和制度都还需要完善,那就边走边看,边看边改,最近的小协议不也是这样么,以开放的心态和稳健的脚步迎接时代变革的到来。
最后,读完本文,你对智能合约一定有了基础的了解,目前2000多个区块链项目的核心竞争力就是他们的智能合约,应用于不同场景的智能合约能否发挥其全部的作用是项目好坏的一个重要的判断方式。