月亮链 月亮链
Ctrl+D收藏月亮链
首页 > ETH > 正文

GAS:引介 | 值得考虑删除的 EVM 功能_以太坊币在中国合法吗

作者:

时间:1900/1/1 0:00:00

为什么「合并」是我们删掉一些东西的最后机会?

原文标题:《引介|值得考虑删除的EVM功能》撰文:VitalikButerin翻译&校对:戡乱&阿剑来源:以太坊爱好者

到2020年,我们对如何设计智能合约和区块链协议的理解已经远超2013-15年。因此,如果我们在2021年从头开始搭建以太坊,我们就不会引入很多早期添加的功能了。然而从一条正在运行的、拥有活跃生态的区块链中移除功能,远比在一个新系统中不添加它们要难得多。

有些「缺陷功能」是无害的。有些可以安全而缓慢地移除或改进。还有些已经深深地嵌入到了太多的应用中,以至于根本改不动。另一方面,也有一些功能要么已经被移除,要么已经被改进,要么即将被移除。

但是还有一些中间情况:有些功能过于复杂,对生态的发展造成了中等程度的伤害,我们可以移除它们,但是需要冒一点风险。如果我们移除这些功能,可能会有少量的应用被破坏。但是不移除的话,它们会继续拖累生态。

就跟别的「长痛短痛」抉择情形一样,人们很容易低估短痛带来的长期收益。特别是在我们的情况中,由于解决复杂情况的代码已经写好了,所以感觉保留它们不需要付出任何成本。但实际上有两个重要的成本要考虑:

为协议开发新实现的成本若要改变功能B,但B会跟没必要存在的复杂功能A交互,可能会产生「交互bug」以重新设计状态树为例:若以太坊的状态越是遵循一些简单的恒常性质,那么替换更高效的双层十六进制Patricia树就会越容易。然而在现实情况中,因为SELFDESTRUCT操作码可以在单笔事务中不受限制地删除大量存储插槽,这给改良状态树带来了很大的困难。另一个例子是2300gas津贴机制使gas重新定价变得更复杂。

币安在萨尔瓦多获得比特币和数字资产服务许可证:金色财经报道,币安表示已在萨尔瓦多获得了两个许可证,成为这个中美洲国家“第一个获得完全许可的”加密货币交易所。这两个许可证——萨尔瓦多中央储备银行颁发的比特币服务提供商(BSP)许可证和萨尔瓦多国家数字资产委员会颁发的第一个非临时数字资产服务提供商(DASP)许可证,允许其提供定制服务。[2023/8/8 21:32:27]

「合并」可能是我们扯掉一些痛苦绷带的最后机会,这篇文章就是解释这样做的理由。

合并是进行最后一轮不兼容更新的一个非常自然的时间节点,有以下几个理由:

合并后构建的客户端很可能不处理PoW链,而是专门验证PoS信标链。因此,如果在合并时或合并前去除不必要的复杂功能,客户端最容易从中受益,因为它们根本不需要实现这些功能。(从技术上讲,即使是在合并前建立的客户端也可以设计成只处理最近1-2个硬分叉之后的数据,但是「PoS信标链作为一条独立的链而不需要处理PoW链上过于久远的数据」的说法更容易让人接受)以太坊已经发生了很大的改变,社区对这将是「以太坊的一次重大升级」达成了共识。特别是「在分片和合并完成之前会出现快速的进化,但合并之后就会趋于稳定」的观点也得到了社区的一致认可。必要的向后不兼容的改变已经发生了。这篇文章将介绍一些可以考虑删除的功能的例子。

Pepe Chain:跨链桥现已正常运行,即将推出新版本:7月21日消息,Pepe Chain发推称,跨链桥现已正常运行,到目前为止,已有1600多个钱包地址桥接至Pepe Chain,即将推出新版本。

此前消息,多名社区用户反馈Pepe Chain跨链资产长时间无法跨回。[2023/7/21 15:51:05]

功能列表

2300gas津贴

这是什么?当一个合约调用另一个合约时,被调用的合约会得到2300gas用于执行非常有限的操作*为何引入?最初是为了让智能合约钱包在收钱时能自动生成一条日志。后来还被用于实现「守卫」功能以防止合约收到ETH。*有何问题?*

*由于它设置的是固定的gas数量,因此只要gas价格可以调整,人们就没有办法确定这些gas到底能支持什么类型的计算。*它并没有很好地满足设计意图,有两个原因。首先,很多用户仍然在使用外部账户,而外部账户并不会生成日志。其次,`SELFDESTRUCT`操作码绕过了津贴机制。从长远来看,通过账户抽象化,外部账户的作用将被弱化,并且`SELFDESTRUCT`操作码可能将被移除,但是在这两件事完成之前,它都只是一个不充分的解决方式。

*如何移除?**有两种可能——要么将2300改成0)要么不限制数量

电影Shadow Song将在Muverse平台上发布原声音乐NFT:4月14日消息,在 Muverse 与 Syndicate Capital 联合举办的 Web Into Entertainment 活动现场,演员孟瑶宣布与 H3 Entertainment 和 Muverse 达成合作,将在 H3 Entertainment 电影项目Shadow Song中参与演出。此外,孟瑶还将与 Muverse 一起发独家音乐 NFT,这种 NFT 将只提供给特定的收藏家群体。NFT 将包括来自孟瑶、H3 Entertainment 和 Muverse 的独家音乐内容。[2023/4/14 14:04:28]

*移除有何副作用?**

*如果我们移除子执行,那么这将需要在合约调用中添加一个笨拙的二分处置,即0gas解释为0,任何其他数字解释为「发送所有的gas」。它还会破坏反接收守卫功能和日志记录。*如果我们在执行中允许子执行获得全部的gas,那么通过调用发送ETH会变成一个需要信任的操作,恶意合约可能会借此扰乱一些应用。不过,Solidity文档已经建议大家用withdrawal模式代替`transfer`,这样就不会有任何风险了。

*如何消除顾虑?**

*让所有的ETH转账,无论是来自调用还是`SELFDESTRUCT`,都生成一条日志,这样钱包就不需要生成日志了*增加一条规则,对于提供0gas的调用,可看做是一个「可以生成日志的`STATICCALL`」。这样就复制了在gas津贴的执行环境里实际做到的功能。

日本JCBA和JVCEA共同发布2023财年税改要求,提出对加密货币单独征税:8月4日消息,日本加密资产商业协会(JCBA)和日本加密资产交易协会(JVCEA)发布了2023年的税改要求,提出对加密货币单独征税,税率为20%。

《2023财年税改要求》谈到了几个问题,这两个组织都认为这些问题阻碍了加密行业的发展。这些问题包括促进税务申报的需要,系统内缺乏一致性,与海外加密资产税收系统的比较,以及加密资产在日本Web3战略中的重要性。(BeInCrypto)[2022/8/4 12:02:06]

剩余Gas额度可见性

*这是什么?**GAS操作码允许合约查看当前的执行环境中还剩多少gas可用。CALL允许调用者为子上下文提供固定数量的gas。

*为何引入?**反对让CALL将父环境中剩余的全部gas都交给子环境的最主要原因是避免「不可信任的调用」:即发送者不信任接受者的调用。一个简单的例子是发送ETH给参与方的金融机制。另一个例子是M-of-N外部价格信息的输入机制,通过调用一些合约,在获得所有合约回复后取中位数作为输出。

*有何问题?**

*其实绝大多数不可信任调用的用例都可以通过其他方式绕过去。对于转账,Solidity文档已经建议大家用withdrawal模式代替`transfer`。M-of-N外部价格信息的输入机制可以很容易地通过为每一个外部输入单独创建一笔交易实现。*这会让gas重定价变得很难做,当操作码的gas消耗量发生变化,固定gas数量的调用可能会不够用。

Gate.io澄清谣言:没有任何限制提币计划,平台运营状况良好:据官方消息,Gate.io执行副总裁Tom Yang表示,关于近期市场对Gate.io限制提币的传言为不实信息。Tom Yang称保障用户资产安全是Gate.io稳健运营九年以来的首要考量,作为一家风控严格的交易平台,Gate.io并未受到熊市过多影响,长期以来营收稳定,资金状况良好,没有任何限制提币计划,目前平台运营状况一切良好。

Tom Yang还表示,Gate.io是全球成立时间最长,最安全的数字资产交易平台之一,真实交易量一直稳居全球前十。作为提供100%保证金审计证明的交易所,Gate.io有能力全方位保障用户的账户、资产及交易安全。

此外,Gate.io正推进其全球战略布局与合规进程,已取得确切的进展和成果,并将于近日公布更多细节。[2022/7/6 1:53:55]

*如何移除?**

*让`CALL`可以自动将父环境的所有可用gas额度都交给子环境。`GAS`操作码只需简单地返回交易的初始gas数量。

*移除有何副作用?**

*我们知道的「不可信任调用的合法用例」主要是第三方赞助调用。第三方发布一笔事务,事务中包含你希望的调用,当调用发生后,可以自动地向你扣费。这对用户没有任何ETH的智能合约钱包、混币者的隐私保护以及其他一些用例都很有用。我们需要一个有限gas数量的调用以确保最终的支付语句真正被调用,而不会因为gas不足而被回退。

*如何消除顾虑?**

*矿工可以直接充当中介,如果交易最终没有付钱给他们,他们就可以直接丢弃事务。参见PhilDaian的工作,他创建了一个由第三方机器人构成的生态,矿工可以自动产生「安全」的批量交易。*在协议内增加一个明确的「第三方付款人」的交易类型。参见EIP2711的例子。

还请注意,如果我们想要走得更远,我们还需要调整63/64规则使得如果子调用失败,父调用也彻底失败。这可能会破坏更多的用例,但它将确保当gas消耗量发生变化时只会引起一种类型的行为变化。

SELFDESTRUCT

请看这篇文章。

Gas退款

*这是什么?**调用SELFDESTRUCT销毁一个合约,或者将一个存储槽设置为零,会退回15000-25000gas。退款会在事务执行的最后触发,并抵扣发送者需要支付的费用。

*为何引入?**激励应用开发者践行「良好的状态卫生」,清除不再需要的存储插槽和合约。

*有何问题?**

*在实践中,几乎没有人真正践行良好的状态卫生。这是因为激励不够高,不值得为此增加代码的复杂度甚至带来安全风险。*退费机制使得GasToken兴起。GasToken有利于将低费率时期的gas调配到高费率时期使用,但是它不利于网络,特别是加重了状态规模的膨胀,并使低效的gas使用方法阻塞了区块链。*它加剧了区块大小的波动,使一个区块实际上的理论最大gas消耗量几乎是字面意义上区块Gas上限的两倍。这并不致命,但仍然不可取,特别是考虑到,在EIP-1559实施后,退款机制可以使网络的实际Gas使用量长期维持高水平,阻碍1559机制的运行。

*如何移除?**只要把退款功能从协议中完全删除。

*移除有何副作用?**

*我们可以相当确信,没有任何应用会因此无法使用,因为退款只在执行结束后触发,所以取消退款并不会改变任何执行的可用gas数量。*GasToken将变得毫无用处*在gas价格反常时,应用失去了降低费用的能力。好在这个功能目前最主要的用户是defi的套利机器人,而套利机器人之间的gas价格竞争是一种零和活动,不过还不清楚移除这个它们用于竞争的武器会造成什么全局性的不利影响。

*如何消除顾虑?**

*Gastoken在他们的网站上已经警告过,未来的协议变更可能会使GasToken无效,所以用户不会觉得惊讶*我们可以提前公布变更时间

其他候选功能

相比上面列举的,我对移除以下功能会带来多少价值缺乏信心,不过还是值得列出一个清单。

*RIPEMD160预编译**:这是一个非标准的哈希函数,很少有项目使用。我们可以用链上部署的合约进行替换,对于真正需要高效验证的项目,可以直接使用ZK-SNARK。

*动态跳转**:使用变量作为跳转目标会使代码的分析和操作变得更加困难。去掉动态跳转,只允许相对偏移的静态跳转,并且为子程序提供一些专用的指针方案可以解决这个问题。然而,这将是一个底层的改变,可能会破坏许多自定义的合约,所以其收益/成本比似乎不如这个列表中的其他项目。

*MODEXP预编译**:对于大整数计算来说,这显然是一个错误的「基本元件」,并且其gas消耗的计算方案也相当复杂。更好的选择是:(i)用预编译的ADD、MUL和MOD作为替代的基本原语,并用这些预编译的指令编写用于替代MODEXP的实现,或者(ii)将EVM384扩展到更多的长度

特别感谢MicahZoltu提出的一些建议

来源链接:hackmd.io

免责声明:作为区块链信息平台,本站所发布文章仅代表作者个人观点,与链闻ChainNews立场无关。文章内的信息、意见等均仅供参考,并非作为或被视为实际投资建议。

以太坊

以太坊

开放的分布式区块链应用平台,通过其专属加密货币Ether以太币提供去中心化的虚拟机,处理点对点合约。允许任何人建立和使用通过区块链技术运行的去中心化应用,没有任何欺诈、审查、第三方监管。以太坊的概念首次在2013至2014年由维塔利克·布特林VitalikButerin受比特币启发后提出,旨在共同构建一个更全球化、更自由、更可靠的互联网。以太坊EthereumETHERC20ERC-20ERC20ERC721ERC-721以太坊2.0查看更多

标签:GAS以太坊AINGate.ioVegasDoge以太坊币在中国合法吗pirate-chaingate.io怎么玩

ETH热门资讯
MAR:特斯拉要推出挖矿手机了 是真的吗?_honey币网址

3月4日,专业汽车媒体TorqueNews在YouTube上发布一段详细介绍特拉斯概念手机「TeslaNeurasmartphoneModelπ」的视频.

1900/1/1 0:00:00
DEX:波卡DeFi大幕将启,Zenlink的流动性捕获手段_ZEN

作为2021的重大事件,波卡平行链拍卖的进展已经进入热身阶段。截至目前,已有包括系统平行链在内的11个平行链项目成功接入RococoV1测试网,Zenlink、Bifrost、ChainX等项目.

1900/1/1 0:00:00
UMB:Umbrella Network (UMB) 上线福利,充值&交易瓜分30,000 USDT_KAMAX

亲爱的BitMax用户:BitMax将于北京时间3月10日22:00上线UMB/USDT交易,现充提已开启.

1900/1/1 0:00:00
以太坊:以太坊EIP1559勘误:不一定会降低矿工收益_ETH

关于以太坊EIP1559,自从这个提案2019年提出来之后,讨论的声音就没有停止过,其中部分矿工群体出现站队现象,甚至有人说提案正式施行之后可能会导致以太坊硬分叉.

1900/1/1 0:00:00
KEX:BKEX Global 关于ETP专区新增MATIC3L、MATIC3S的公告_FuzzBalls

亲爱的BKEXer:BKEXGlobalETP专区将于2021年3月10日14:00上线MATIC3L、MATIC3S.

1900/1/1 0:00:00
比特币:数据不会说谎 25张图表参透本轮牛市_BIT

如果回顾过去几个月里加密货币行业发生的事情,你会发现市场表现非常乐观。叙事固然重要,但数据同样不会说谎,所以我们决定花些时间,通过数据来展示这段时间加密货币行业增长情况.

1900/1/1 0:00:00