状态保质期是目前解决状态增长问题的推荐方案。
在本文中,我们将状态保质期视为一种会定期让完整状态树失效的机制。本文将讨论如何存储之前的周期,因为我们的关注点就是如何复活已经被遗忘的状态——无论?n=0?还是?n=1。
以下总结了一些机制提案:
清空
顾名思义,“清空”就是什么都不剩:过了保质期的状态会立马失效,如果用户需要使用已失效状态中的部分数据,必须提供对应的见证数据。请注意,若要读取或写入还未在有效状态中初始化的部分,用户?必须?提供证明:要么是一个除外证明来表明这部分数据在之前任意时刻都没有初始化,要么是一个具体时间点的证明,然后再提供一个除外证明来表明这部分数据在这个时间点之后没有改变过。
PaxosTreasury销毁64,087,057枚BUSD:金色财经报道,Whale Alert监测数据显示,北京时间2023年2月18日05:59,PaxosTreasury销毁64,087,057枚BUSD。[2023/2/18 12:14:25]
利
非常简单
弊
除外证明的大小会随时段数量呈线性增长,让初始化状态数据的成本变得异常高
逃避了地址冲突问题
带周期标记的地址
清空元数据的主要问题在于,初始化新的状态元素会产生很高的成本。通过让地址带上周期标记,以太坊协议可以创建一种机制来避免在初始化新的状态数据时产生地址冲突。鉴别器会设定账户最少能够存活到哪个时段。目前有两种方法可以实现PWA:
数据:币安将超6亿枚USDT从热钱包转至冷钱包:1月18日消息,据派盾预警监测,币安将6.056亿枚USDT从Tron链上热钱包(标记为Binance-Hot)转至冷钱包(标记为Binance-Cold 2)。
据统计,目前币安在Tron上持有约130亿枚USDT。[2023/1/18 11:18:46]
地址空间扩展
Vitalik的文章
Ipsilon的文章
太长不看:同时允许传统的20个字节的地址和32个字节的ASE前缀地址存在。在以太坊虚拟机中创建一个环境变量来修改涉及地址的操作码的行为,具体视相关地址是传统地址还是ASE地址而定。
比特币矿企Hut 8任命IBM Canada前高管担任CFO:金色财经报道,比特币矿企Hut 8宣布任命Shenif Visram担任首席财务官,Shenif Visram将常驻多伦多并向首席执行官Jaime Leverton汇报工作。Shenif Visram曾任职于IBM Canada、Cogeco Peer1和Aptum Technologies,将在Hut 8帮助把业务战略性扩展到高性能计算领域。(prnewswire)[2022/12/14 21:42:37]
利
新的状态无需证明即可初始化。
可扩展以保存其它元数据。
解决地址冲突问题。
公链Sui推出3种新的支付交易类型Pay、PaySui和PayAllSui:11月3日消息,公链Sui发推宣布,3种新的支付交易类型Pay、PaySui和PayAllSui已经作为Sui 0.14.0的一部分发布,替代TransferSui、SplitCoin和MergeCoin。目前三种较旧的方法暂时仍然有效,Sui将在删除它们之前提前通知社区。
Sui表示,新的支付方式提供了更大的易用性,更高的灵活性,并且可以以更少的代币管理开销支持各种场景。[2022/11/3 12:14:01]
弊
需要对EVM进行大量修改。
需要创建两种不同的EVM环境,分为传统模式和扩展模式。
转换映射将无限增长,而且无法用过期机制来抛弃似乎是可以有过期机制的,只不过要承担一些地址冲突的风险。
用户体验不佳,因为用户可以将资产存储在三种类型的地址上。
并非所有Solidity编译的合约的掩码地址都有160位,因此一些合约的地址可能会存在高阶脏位。
免扩展的PWA
Vitalik?的文章
太长不看:找到一个未使用过的4个字节的前缀,并禁止在旧规则下使用该前缀创建新的合约/地址。旧合约在传统模式下执行,只可根据旧规则创建新的地址。新类型的合约在PWA模式下执行,只可创建新的合约
利
新的状态无需证明即可初始化。
对EVM的修改相对较少。
不需要转换表,用户只需要考虑一种地址。
不会破坏现有工具而非原像?)
弊
发生地址冲突的概率较高,不再有反事实合约。
不是一个很有吸引力的解决方案,可能会让地址扩展变得越来越难。
周期元数据
状态树元数据
这个想法应该还没有被正式定义,但它的大体思路是在状态树中的账户对象处增加一个新的字段来表示创建时间。这样可以解决因除外证明而导致新的存储项初始化成本过高的问题,但是不会改善为创建新账户而创建新账户的问题。
利
如果是新合约,无需证明即可初始化新的存储项。
非常简单。
可扩展以保存其它元数据。
不会因为外部映射而导致状态无限增长。
不会破环现有工具。
弊
逃避了地址冲突问题。
创建新账户的成本很高,需要除外证明来表明该账户自周期0以来就不存在。
外部时段注册表
这个想法也没有被正式定义,大体思路是引入一个新的注册表树来存储状态保质期的元数据。这个注册表不会过期,并且会存储合约的创建时段。另外,它还可以存储其它信息,如存储项的总数量。只要有效存储量等于合约的总存储量,合约时段就可以升级成当前时段。类似方案也可以应用于EWA提案,但是需要修改状态树。
利
新的状态无需证明即可初始化。
可扩展以保存其它元数据。
不需要转换表,用户只需要考虑一种地址。
不会破坏现有工具。
弊
新的状态树结构。
无限增长。
逃避了地址冲突问题。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。