第二章 详解以太坊

以太坊原理

以太坊通过建立终极的抽象的基础层-内置有图灵完备编程语言的区块链-使得任何人都能够创建合约和去中心化应用,并在其中设立他们自由定义的所有权规则、交易方式和状态转换函数。

图灵完备:能够运行非常复杂的运算,最简单的理解是它支持循环的操作,而比特币的验证是不支持循环的。

以太坊虚拟机(EVM)是以太坊中智能合约的运行环境。它不仅被沙箱封装起来,事实上它被完全隔离,也就是说运行在EVM内部的代码不能接触到网络、文件系统或者其它进程。甚至智能合约与其它智能合约只有有限的接触。

对比比特币

image

外部账户:可用私钥控制的

合约账户:一旦创建,只能是合约里面的代码控制,不能人为控制,但可以人为触发

有向无环图DAG ( Directed Acyclic Graph)

image

因为以太坊是12s出一个块,所以在12s内可能出现上图的状况,其实在实际情况中,高度2的两个块后面可能还有很多其他块,我们选择最长的当做主链,如果是比特币的话,未做主链的块不会得到任何奖励,如下图

image

而以太坊的话,会给未做主链的块适当奖励,如下图

image

状态转移

image

以太坊区块链

image

临时分叉

image
image

区块头

image

ommerHash:包含叔区块的Hash

beneficiary:挖洞矿后奖励的存放地址

logsBloom:日志过滤器

number:交易数量

gasLimit:要运行以太坊付出的花费限制

gasUsed:运行以太坊的花费

mixHash:和nonce结合起来做挖矿运算

stateRoot:账户所有信息会生成一个Merkle patricia tree,把树根存储在其中

transactionsRoot:所有的transaction形成Merkle patricia tree,把树根存储集中

receiptsRoot:为每一个transaction做了一个收据,把收据集合起来形成Merkle patricia tree

以太坊账户

包含四个部分:

  • 序号,用于确定每笔交易只能被处理一次的计数器,参与生成交易的id
  • 账户目前的以太币余额,以太币(Ether)是以太坊内部的主要加密燃料,用于支付交易费用。 以太币的最小单位为Wei, 最大单位为以太,1 Ether=10^18Wei
  • 账户的合约代码,如果有的话
  • 账户的存储(32byte to 32byte key-value map)

账户信息被称为world state,放在db上管理

外部账户:用户用公钥、私钥控制

合约账户:由合约编译后的code控制

tips:外部账户和内部账户,是在相同的地址空间,相同的数据结构有不同的功能

重放攻击

image

Gas

什么是Gas(气)?

由以太坊网络上的交易而产生的每一次计算,都会产生费用,这个费用是以称之为”gas”的来支付,gas就是用来衡量在一个具体计算中要求的费用单位,智能合约最原子运算所需花费的单位。
例如 :一个位移运算需要1气,一个相加运算需要3气;

gasPrice

1气和以太币(wei)的兑换价格

一次Transaction的所有花费

Total_fee= value (转移给对方账户的以太币数量)

  • transaction fee
  • gas* gasPrice (执行智能合约的花费,此为上限,以实际执行步数为准,gasReal*gasPrice)

Gas Limit

允许的最大花费:以太坊中有循环操作和一些其他复杂的操作,限制最大花费。


image

交易

image
image
image

智能合约(Smart contract)

  • 智能合约概念于1995年由Nick Szabo首次提出。
  • 是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。
  • 智能合约的目的是提供优于传统合约的安全方法,并减少与合约相关的其他交易成本。
  • 一个智能合约是一套以数字形式定义的承诺,包括合约参与方可以在上面执行这些承诺的协议。

智能合约的定义

“智能合约”- 根据事先任意制订的规则来自动转移数字资产的系统。

Smart contracts are pieces of code that live on the blockchain
and execute commands exactly how the were told to.

智能合约就是存储在区块链上的代码,用以实现执行特定的功能。

例子:

if HAS_EVENT_X_HAPPENED() is true:
    send(party_A,10000)
else:
    send(party_B,10000)

一个运行在安全环境下的计算机程序,可以直接控制数字资产.

安全环境:

  • 由可信的人,组织运行的服务器(公有云).
  • 准去中心化的计算机网络(私有链).
  • 去中性化的计算机网络(公有链).

法律合约:”我承诺如果X发生的话,则给你发送10000元”.

智能合约:”我将10000元发送给一个计算机程序,如果X发生了,这个程序会把10000元发送给你,否则将返还给我”.

tips:法律合约可能会出现耍赖的情况

一个运行在安全环境下的计算机程序,可以直接控制数字资产.

  • 域名
  • 房地产权
  • 证券
  • 票据
  • 专利许可证
  • 游戏装备
  • 数字货币...

为什么要用智能合约:

  • 自动处理
  • 减少依靠信任的程度。信任依赖集中在数量很少的数据源,而不是大量的合约执行机制。

智能合约 VS 法律合约

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

推荐阅读更多精彩内容