Solidity智能合约开发 — 5.1 -理解EVM虚拟机状态、交易、收据和区块

EVM是以太坊协议核心组件之一,有独立的指令集、内存、存储和其他一些相关要素。以太坊可以看作一个由交易所驱动的状态机。

1 状态

以太坊的所有操作和数据都是根据“账户”来区分和标识的,以太坊的账号(无论是外部账户还是合约账户)都会有一个4字段所组成的数据元组来表示其状态。其账户状态如下表:

表5-1 账户状态字段结构
字段名称描述
nonce如果nonceHash为空,这个值等于由此账户所发出的所有交易数量;如果nonceHash为某段EVM代码的哈希值,则这个值等于由此账户所创建的合约数量
balance等于该账户所拥有的以太token数量,以wei为单位
storageRoot用于保存账户全局唯一的存储树根节点哈希值
codeHash与此账户相关联的EVM代码哈希值

2 交易

交易时触发状态变动的唯一途径。交易数据的字段结构如下:

表5-2 交易数据的字段结构
字段名称描述
nonce由交易发送者所发出的所有交易数量
gasPrice执行这个交易所需要计算不住消耗的每单位gas的价格
gasLimit执行这个交易的最大gas数量,在交易开始前设置,设定后不能再增加
to消息调用接收者地址,对于合约创建交易,此字段为空
value转移到接受者账户的wei数量
v一个用来构成交易签名的第65字节长度数据
r一个用来构成交易签名的第1-32字节长度数据
s一个用来构成交易签名的第33-64字节长度数据
data这个交易为“合约创建”时,其数据被认为是账户初始化程序的EVM代码,当这个交易为“消息调用”时,其数据被认为是合约函数调用数据(ABI编码)

3 收据

        区块数据中有一个字段是receiptRoot, 他的值是这个区块中所有交易的“收据(receipt)”所组成的树(tie)的根节点哈希值。每一个区块都有一个独立的收据树,树的整体数据由各节点分别维护,只把这个树的根节点哈希值保存到区块中。

        每个交易的交易收据都是一个有4个元素的元组。

  • 交易执行之后的状态树根节点哈希值(medState)
  • 区块中当前交易执行完成后的累计gas使用量。
  • 交易过程中创建的日志(log)集合。
  • 由交易日志所构成的Bloom过滤器。

此外,我们可以定义事件的代码中将某个事件参数声明为indexed;指定将这个参数的值放入Bloom过滤器,对于这些指定为indexed的事件参数,我们就可以通过JSON-RPC或者Web3接口的filter功能对其实际值进行查找过滤。

4 区块

以太坊的区块有3个部分组成:block header、transaction list和Ommer Block Header

表5-4 区块头数据的字段结构
parentHash父区块头的keccak256哈希值
ommerHash当前区块的ommers列表的kaccak256哈希值
beneficiary成功挖到这个区块所得到的所有交易费的160位接受地址
stateRoot所有交易被执行完且区块定稿后的状态树的根节点的keccak256哈希值
transactionsRoot当前区块中所有交易所组成的树的根节点的keccak256哈希值
receiptsRoot当前区块中所有交易的收据所组成的树的根节点的keccak256哈希值
logsBloom当前区块中所有交易的收据数据中的可索引信息组成的Bloom过滤器
difficulty当前区块难度水平的纯量值
number当前区块的祖先数量(创世区块这个值为0,其他是区块的顺序号
gasLimit目前每个区块的gas开支上限
gasUsed当前区块的所有交易所用掉的gas之和
timestamp当前区块初始化的unix时间戳
extraData与当前区块相关的任意字节数据
mixHash256位的哈希值,用来与nonce一起证明当前区块已经承载了足够的计算量
nonce64位的哈希值,用来与mixHash一起证明当前区块已经承载了足够的计算量

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Solidity智能合约开发实验中的实践项目中,我们创建了一个简单的投票合约。该合约允许用户创建投票,并为每个候选人投票。我们将讨论实验结果和分析如下: 1. 合约功能实现:我们成功实现了合约的基本功能,包括创建投票、为候选人投票、获取候选人得票数等。合约在以太坊区块链上部署后,可以被用户调用并执行相应的操作。 2. 投票操作:我们测试了多个用户对不同候选人的投票,并验证了合约正确地记录了每个候选人的得票数。通过合约的查询功能,我们可以准确地获取每个候选人的得票数。 3. 安全性分析:我们对合约进行了一些基本的安全性分析,确保它没有明显的漏洞。例如,我们防止了重复投票和未注册候选人的情况。然而,这并不能保证合约完全安全,因为Solidity编程语言本身存在一些潜在的安全问题。 4. 性能评估:我们测试了合约在处理大量投票时的性能。我们发现,在处理数千个投票时,合约的执行速度较快,并且能够快速更新候选人的得票数。 5. 可扩展性分析:我们考虑了合约的可扩展性。尽管我们的实验中只创建了一个简单的投票合约,但我们通过使用合约中的动态数组和映射等数据结构来支持更多的候选人和投票。 总体而言,我们的实践项目取得了成功,并且满足了设计和功能要求。然而,我们仍然需要进一步的测试和安全审查来确保合约在实际使用中的可靠性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值