你可能听说过「智能合约」,甚至可能知道它们是在区块链上运行的代码。但是你如何才能在区块链上运行代码?这不是可以轻易理解的简单概念。本文解释了智能合约是如何在以太坊区块链上运行的。对编程的基础理解将会有所帮助,因为本文包含了一些用于举例的简单代码。为了清晰起见,本文将其中的一些技术细节稍微进行了简化,但概念是有效的。
原文标题:《UnderstandingEthereumSmartContracts》
原文作者:GjermundBjaanes
翻译:蓝狐笔记社群Dyna
一、区块链——快速入门
这里不讲太多细节,区块链技术的核心概念是分布式账本。它是一种在众多参与者之间共享的特殊类型的数据库。
这个特殊的数据库就是一个交易列表,记录了网络中发生的每一笔交易。每个人都有一个副本。这种去中心化分布结合强有力的货币激励措施,消除了各方之间信任的必要性。
传统意义上,当事人之间的信任是通过中间人,即第三方来解决的,比如Paypal、银行。与你不信任的人之间的交易将通过双方都信任的中间人进行。
有了区块链,这种需求消失了。因为你可以把你的信任放在网络上,在这里,强有力的激励措施消除了作弊的欲望(简而言之:遵守规则更有利可图)。
广州市市长郭永航带队深入调研“元宇宙”产业发展:金色财经报道,智度股份(000676)官微消息,3月2日上午,广州市市委副书记、市长郭永航带领市政府领导班子一行考察智度股份与国光电器(002045),深入一线调研“元宇宙”产业发展情况,并就企业在“元宇宙”领域的技术、人才、市场以及创新等方面情况进行了充分交流。(同花顺)[2022/3/3 13:35:08]
更具体地说:区块链网络是一组机器,它们记录着相同的交易列表副本(例如,从A转给B的钱)。
因为每个人都有相同的列表,所以很难网络接受错误的交易。结合一些加密算法和货币奖励以便遵守规则,你的网络会非常安全。
所有这些也使得区块链几乎是不可变的,因为改变历史记录的唯一方法是获得全网大多数人的同意。
二、什么是智能合约?
区别于比特币,以太坊最大的不同是引入了智能合约的概念。比特币是数字货币,以太坊也是数字货币,但远不止这些。
「智能合约」这个名称有点误导人。它们不是真正的合约,也不特别智能。它们只是一些可以运行在区块链上的代码-或者说是计算机逻辑运算。
首先,我将介绍有关智能合约是以太坊网络上的一种特殊账户。你有用户账户,你还有智能合约账户。
中央财经大学郭田勇:应深入研究如何用数字人民币组建更多功能:中央财经大学中国银行业研究中心主任郭田勇表示,在数字化的浪潮下,货币作为一种支付媒介,其本身的数字化是必然趋势。考虑到传统货币印制发行成本高、不易携带等局限,数字货币以其独特的优势,极大降低了交易成本。郭田勇指出,数字货币如果由政府或者中央银行来主导,必须协同好同原有银行体系为主导的支付关系。目前,中国的数字货币属于M0范畴,从金融学角度看,M0并不具有货币创造的能力,在整个货币储存量中占比也很小,因此,数字人民币的范围还非常有限,未来如何用数字人民币组建更多的功能,将其推向更大的领域,值得深入研究。这是一个循序渐进的过程,要把握好节奏。郭田勇称,数字人民币前期推进比较成功,有利于提升人民币国际化程度。随着中国经济实力增强,人民币国际业务更为广泛。面对庞大的国际结算量,数字货币高支付效率的优点更易凸显。(中国新闻网)[2021/7/7 0:32:14]
一个用户账户包括:
一个地址
余额
一个智能合约账户包括:
一个地址
余额
一个状态
代码
外汇管理局山西省分局深入推进跨境金融区块链服务平台应用:外汇管理局山西省分局近日出台了《国家外汇管理局山西省分局关于千方百计支持中小微外贸企业复工复产健康发展的指导意见》,提出多项具体措施精准帮扶中小微外贸企业。在缓解融资难题方面,深入推进跨境金融区块链服务平台应用,为中小微外贸企业跨境结算与融资扩渠道、增便利。(生活晨报)[2020/5/8]
地址和普通账户的地址是一样的,它是该账户的唯一识别符。
余额和普通账户也是一样的概念。唯一令人激动的是,智能合约上的余额意味着代码可以拥有金钱。它可以处理这些钱,也可能因为编码错误而造成处理不当。
智能合约帐户的状态是智能合约中声明的所有字段和变量的当前状态。它的工作方式与大多数编程语言中类的字段变量相同。事实上,一个类的实体化对象可能是理解智能合约的最简单方法。唯一的区别是这个对象是永久存在的(除非被编程为自我毁灭)。
智能合约的代码是编译好的字节代码,以太坊客户机和节点可以在上面运行。它是在创建智能合约时执行的代码,并且包含可以调用的函数。就像面向对象编程的语言中的任何对象一样。
关于智能合约的趣事:它们可以调用其它的智能合约。这就开启了创建自主代理的能力,这些代理可以自己花钱和进行交易。
何玺:高层对区块链有过深入研究:就《人民日报》第17版财经周刊刊登了整版3篇关区块链的专题报道,围观者众。资深媒体评论人,酷科技创始人何玺巴比特专栏发文称,由此可见高层已经对区块链技术有过深入的研究,并达成了“共识”,即把区块链技术定为了“兵家必争之地”、是“战略机遇”、更是“国家战略”。[2018/2/27]
假设我用上面的代码创建了一个智能合约。该代码有一个名为counter的字段,类型为uint(整数)。counter变量的内容是本合约的状态。每当我调用count()函数时,任何人都能看到这个智能合约在区块链上的状态将会加1。
稍后我们将通过更多的例子来解释它是如何工作的,但首先我想回到以太坊和比特币的交易,并以此来解释一些事情。
三、交易水平上,以太坊VS比特币
比特币交易非常简单。你可以只做一件事。一种类型的交易。略过一些细节,一切都可以归结为TO,FROM和AMOUNT。这使得比特币成为一种价值储存手段,能够在网络参与者之间传递价值。
以太坊的不同之处在于交易还有一个「DATA」字段。该「DATA」字段支持三种类型的交易:
价值转移
英国金融监管机构发出承诺 将对新兴的ICO市场进行深入审查:金融市场行为监管局周五表示,将对ICO市场进行审查,以此作为更多监管行动的前奏。它已经告诫消费者与投资ICO有关的“非常高的风险”。“在初始投币(ICO)市场上,FCA将收集进一步的证据,并对快速发展进行更深入的研究。调查结果将有助于确定在9月份发布的消费者警告之外是否需要在这方面进一步采取监管行动。“FCA在一份声明中表示。[2017/12/15]
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
据CoinGeek消息,澳本聪向RogerVer提起诽谤诉讼。据悉,澳本聪对RogerVer的诽谤诉讼依据,是4月15日发布在Bitcoin.com官方YouTube频道的一段视频,该视频名为“.
1900/1/1 0:00:00本月早些时候,科技媒体Motherboard发现,黑客不仅可以访问Outlook用户的电子邮件元数据,还可以获取邮件内容.
1900/1/1 0:00:00香港财政司司长陈茂波则在会上表示,目前有超过550家金融科技公司及初创企业在香港设立总部,过去5年,这些企业已筹集了超过11亿美元资金,超过日本、新加坡及澳大利亚等其他国家.
1900/1/1 0:00:00Gate.io已经于2019年5月6日凌晨0-2点完成系统升级,目前已经支持点卡抵扣现货和杠杆手续费,用户无需特殊操作,只要账号中有点卡,系统就会在您现货和杠杆交易过程中优先使用点卡抵扣手续费.
1900/1/1 0:00:00DragonEx新增LTC/USDT杠杆交易对2019-05-04亲爱的用户:DragonEx将于2019年5月4日15:00(UTC8)对LTC/USDT交易对开启杠杆交易功能.
1900/1/1 0:00:00据《币世界》行情显示,BTC冲高回落,目前在5770USDT附近震荡。BTC币安现报5771.24USDT,24小时涨幅4.78%.
1900/1/1 0:00:00