以太坊智能合约的关键概念及设计要点

前言:本篇作为学习笔记的第四篇,重点分析智能合约的技术构成及设计要点,部分基础概念基于前面篇章内容之上不再解释,但会对和智能合约开发相关的重要概念强化及扩展讲解。同时,还会演示在实际环境上创建一个简单的智能合约,包括框架设计及代码编写、本地部署、测试等完整实际操作。

一、智能合约的定义

智能合约可简单看作是一种计算机协议或者程序,部署后可自我执行和自我验证对,不需要人为干预。具有以下基本属性:

1)合约的执行会产生可被验证的证据,以确保来验证合约操作的有效性

2)合约在部署之前其相关的条款和执行逻辑都已制定好,一旦部署则不能再更改

3)合约通常会提供一个用户接口,供用户和合约进行交互,这些交互行为则遵循意定制好的逻辑

同时,合约具有诸多的优点,其中被认为推广最为重要的是:1)去中心化权威性,合约对的监督和仲裁都由系统自行完成;2)执行效率和较低运营成本相对应,多方之间的交互成本和违约成本,以及人员成本都会下降。

二、以太坊智能合约关键概念强化

(1)合约账户

前面讲过以太坊区块链中存在账户的概念:外部所有账户和合约账户,外部所有账户创建合约账户,并完成部署智能合约。

一个外部账户是由一对私钥和公钥来确定,每个账户有一个地址即公钥最后的20个字节,每个账户对的地址和私钥都被编码成为一个JSON格式格式的“钥匙文件”,并且是经过加密的。私钥用来对外部账户的所有交易进行签名,而加密所使用的密钥是在创建账户时所输入的密码。

合约账户为智能合约的实际载体,具有以下特点:

可以存储以太币;

可支持智能合约代码;

可相应别的用户或合约执行此智能合约的请求,并返回结果;

可调用别的智能合约。

这里还有两个概念需要注意

以太坊智能合约的关键概念及设计要点_第1张图片

(2)以太币和Gas

以太币是整个以太坊区块链驱动自我运转的一种基本激励制度,类似于比特币。以太坊上的所有账户管理操作以及智能合约部署、执行均需要支付以太币才能运转。以太币也是由矿工挖矿产生,由两部分组成

以太坊智能合约的关键概念及设计要点_第2张图片

Gas则是指智能合约在以太坊上每执行一步所支付的费用的基本单位,Gas相当于部署和执行智能合约多需要的燃料,而燃料的价格最终转化为以太币的值来体现,所以以太坊上的所有用户需要通过挖矿或者购买以太币来补充燃料。

与Gas相关的还有以下概念

以太坊智能合约的关键概念及设计要点_第3张图片

而Gas的消耗会出现在下列三种情况中

1)需要执行特定的内部抽象操作时

2)进行一个从属的消息调用或合约创建时

3)需要增加账户内存使用量时,特别是支付费用的账户内存使用量应该是32个字节的整数倍,以保证使用的所有内存都包括在计费范围内,如果使用33个字节,则需要支付两个32字节的费用。

(3)智能合约的执行抽象

以太坊可以被看作是对所有具有状态的对象的管理,每个对象状态会随着新区块的产生而发生改变,并被记录在以太坊区块链之上,而以太坊的状态转换可以定义为以下公式

(σ',g',s,l,r,o)= F状态转换(σ,g,I

其中假设以太坊网络状态为σ,合约运行剩余Gas为g,信息元组I包括信息

Ia:当前代码的合约地址

Io:发起该次合约交易的发起者地址

Ip:用户为这次交易设置的Gas价格

Id:这次交易的输入数据,该输入的数据解雇是一个数组

Is:执行这次合约的账户地址

Iv:合约账户的余额

Ib:用于执行虚拟机代码所需的数组

IH:目前区块的数据头

Iε:目前执行的CALL操作和CREATE操作的数量

上述公式左边为合约执行之后的状态装换,其中σ'为系统运行后状态,g'为运行后剩余Gas,s为执行终止操作的合约列表,l为记录序列,r为运行后返还的Gas,o为合约运行后所产生的输出。

关键的F状态转化是一个不断迭代系统临时状态和虚拟机临时状态的过程,而迭代的种种有两个条件所决定:

1)系统状态是否出现异常而使虚拟机停止工作,诸如Gas不足、指令无效、虚拟机堆栈容量不足等。

2)虚拟机在正常状态下停止工作,例如所有指令执行完毕返回结果。

(4)部署流程

在以太坊上部署和运行智能合约需要以下几个步骤:

1)启动一个以太坊节点(如geth)

2)编写智能合约(例如使用Solidity智能合约语言)

3)使用sloc编译器将编写好的合约代码转换为以太坊虚拟机位码

4)将编译好的合约代码部署到网上(需要消耗用以太币购买的Gas),需要合约发起账户使用外部账户对待部署合约进行签名,通过矿工确认后将合约代码存于以太坊区块链上。之后,用户可以获得合约的地址以及调用合约所需的接口。

5)使用web3.js库所提供的JavaScript API接口来调用合约(这一步也会消耗以太币)。

基本过程可抽象如下图

以太坊智能合约的关键概念及设计要点_第4张图片

三、智能合约设计及实操(待补充)

内容包括:

环境准备及工具选型

简单智能合约框架设计及部署

智能合约执行测试及问题

你可能感兴趣的:(以太坊智能合约的关键概念及设计要点)