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

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

一、智能合约的定义

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

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

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

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

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

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

(1)合约账户

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

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

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

可以存储以太币;

可支持智能合约代码;

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

可调用别的智能合约。

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

(2)以太币和Gas

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

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

与Gas相关的还有以下概念

而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接口来调用合约(这一步也会消耗以太币)。

基本过程可抽象如下图

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

内容包括:

环境准备及工具选型

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

智能合约执行测试及问题

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容

  • 简介 不管你们知不知道以太坊(Ethereum blockchain)是什么,但是你们大概都听说过以太坊。最近在新...
    Lilymoana阅读 3,891评论 1 22
  • 以太坊(Ethereum ):下一代智能合约和去中心化应用平台 翻译:巨蟹 、少平 译者注:中文读者可以到以太坊爱...
    车圣阅读 3,743评论 1 7
  • 前两天我把我一些以前之前看过的书清理了出来,然后放到杂物房,,我爸妈问了我一句,这些书你都不要了吗?之前花了那么多...
    海峰匠阅读 258评论 0 0
  • 是时候为今天种下的好种子浇水施肥了。近期目标是让我们位于郑州市中原路前进路交叉口西北角的三沙湾酒店,员工稳定,结合...
    金刚家人阅读 91评论 0 1
  • 2018年3月17日 星期六 沙尘 “抱团成长,第370篇。” 婚姻是需要经营的,话没错。几天不经营就觉得不是那么...
    161d968e601f阅读 121评论 0 0