阅读 246

Conflux的 CVM 和 EVM 虚拟机层的主要区别

将 EVM 字节码移植到 Conflux 上

Conflux 完全继承了 EVM 的虚拟机,所以 EVM 的代码可以直接在 Conflux 上跑。但是,由于 Conflux 采用了不同的共识机制,并且引入了存储押金机制,所以有一些细节上的不一样。

此外,Conflux 还有一些新功能,比如允许合约赞助者为用户代付交易费。这些不属于代码移植中的问题,我们将在其他的文章中说明。

存储押金机制产生的区别

Conflux 采用了存储押金机制。执行智能合约时,如果通过 SSTORE (0x55) 指令往存储中写入非零数据的时候,则需要支付存储押金。当这段数据被清空时,存储押金会被退还给支付者。

存储押金的价格是 1/1024 CFX/byte. 每个存储单元计 64 字节。除此之外,合约创建后,代码也要收存储押金。

交易的存储上限域

在 Conflux 中,每个交易需要填写存储上限,单位是字节。如果存储上限填写的过高,超过了账户余额所能支付的存储押金,交易就会失败。如果存储上限填写过低,导致交易执行结束时实际新增的存储超过了存储上限,交易也会失败。

一个最简单的方案是,通过 Conflux RPC 估算(详见相关章节)交易需要的存储上限。或者,可以通过 n*1024 的公式计算账户余额最高支持的存储上限。(其中 n 为支付了交易费和账户转账费用后的余额。为了保险起见,也可以填一个小一点的数,如 n*1000

写存储消耗的燃料

在 Conflux 中,所有 SSTORE (0x55) 指令消耗的燃料都是 5000 gas. 相比较,以太坊在这里的逻辑很复杂。不过,一般开发者不需要关心每个指令的具体 gas 定价,只需要通过 RPC 估计整个交易的燃料用量就可以了。

共识机制产生的区别

区块高度和区块哈希相关的指令

在以太坊中,BLOCKHASH (0x40) 指令 (Solidity 中的 block.blockhash(n) 函数) 接受区块编号(区块高度) n 作为输入,输出区块高度对应的哈希值。其中参数高度 n 与交易执行时所在区块高度相差不可以超过 256,否则会返回 0.

Conflux 采用了树图结构,当区块排序后,每一个区块会产生一个排序编号,这个排序编号不同于区块高度可能不同。因为树图结构排序后,相邻的两个区块可能没有父子关系,所以编号为 n-1 的区块不一定是编号为 n 区块的父亲区块。

Conflux 中 BLOCKHASH (0x40) 指令 (Solidity 中的 block.blockhash(n) 函数)接受区块排序编号 n 作为输入。相应的,NUMBER (0x43) 指令(Solidity 中的 block.number 变量)得到的也是排序编号。

此外,以太坊的 BLOCKHASH (0x40) 指令可以询问交易所在区块前 256 个区块的哈希值,而 Conflux 的指令只能询问前一个区块的哈希值。但是,Conflux 的参数数量和以太坊没有区别。

出块速度

Conflux 的出块速度是每秒 2 个块,比以太坊快很多。如果智能合约的代码逻辑里硬编码了出块速度,需要作出相应的改变。

交易中的信息填写

当用户发起一笔交易时,Conflux 所需要填写的信息有所区别。不过一般 RPC 和 SDK 会替开发者和用户做好这件事情。

  • Storage Limit: 存储上限。详见 交易的存储上限域 小节。
  • Gas Limit: 燃料上限。 对于未用完的 gas, Conflux 最多只退还 Gas Limit 的 1/4,所以发出交易前,务必估计一个比较准的燃料上限。
  • Chain ID: 区块链编号。规定可以执行这笔交易的区块链编号,避免有人将测试网的交易拿到主网上重放。目前,测试网的 Chain ID 是 1,主网的 Chain ID 是 2.
  • Epoch Height: 交易执行时的(大概的)epoch. 如果交易执行时实际的 Epoch 与交易填写的 Epoch Height 相差 100000 以上(Epoch 编号增长 100000 的时间在半天到几天不等),交易将执行失败。也就是说,过长时间未被打包的交易将无法执行。
  • recipient: Conflux 的地址算法与以太坊有区别。所有公钥生成的地址前四个 bits 都是 0001,所有合约地址前四个 bits 都是 1000. 所有内置合约地址前四个 bits 都是 0000. 如果收款地址 recipient 的前四个 bits 不是这三者之一,交易执行失败。

其他区别

  • 合约创建后,创建者(即合约创建时的 msg.sender)自动成为合约的管理员。管理员有权销毁合约,或转移管理员权限给他人。管理员可以是普通地址,也可以是合约地址。
  • Conflux 创建的合约代码上限是 49152 字节,比以太坊多一倍。
  • 请检查自己的合约里有没有硬编码以太坊的相关地址。
  • Conflux 中还有一些其他的区别,是合约的开发者与使用者不需要关心的,这里我们略去。