如何将你的合约升级到Solidity 0.8?

我们离 Solidity 1.0 的发布越来越近了(当然除非 0.9 之后是 0.10)。Solidity0.8在0.7 发布之后仅 5 个月就发布了!

登链社区正在同步翻译 Solidity 0.8 的文档

今天我们就来探讨一下如何把合约迁移升级到 0.8 版本... ...

我们来看看两个大的新功能:集成的 SafeMath 和新的错误处理。

没错,你不需要再导入 Openzeppelin SafeMath了。最重要的是,你不需要做任何事情就可以激活 Solidity 集成的 SafeMath。只要写上a+b,就会在溢出时自动回退交易。

你可能会在 Remix 等工具中看到如下错误提示,因为 0.8 还没有完全支持。比如溢出还没有给出确切的原因。

 transact to Solidity08.test errored: VM error: revert. revert但这种情况在未来应该会有所改变。

如果你确实就希望代码能够溢出呢?还是非常在意 Gas 费了?

则通过 unchecked形式包装语句来停用 SafeMath:

contract Solidity08 {    function test() external pure returns(uint256) {        // 默认使用 SafeMath ,此时会回退        uint256 x = 0;        x--;        return x;    }}contract Solidity08 {    function test() external pure returns(uint256) {        // 不使用SafeMath,返回 type(uint256).max        uint256 x = 0;        unchecked { x--; }        return x;    }}2. 无效的操作码被还原取代到目前为止,某些操作会导致 INVALID操作码的执行。这个操作码的问题是,它消耗掉所有剩余的 Gas。这显然是不好的且没必要。为什么要浪费 Gas,把它捐给矿工?

数据:ETH平均gas使用量达4个月以来低点:12月12日消息,Glassnode数据显示,ETH平均gas使用量(7d MA)刚刚达到4个月以来的最低点40152.494。[2021/12/12 7:34:01]

更多细节,在这里查看 revert和 assert的区别。

现在 Solidity 使用revert操作码。为了区分常规 revert 和系统内部错误(panic),Solidity 在返回数据前加上一个标识符:

常规 Revert 错误以keccak256(Error(string))的前四个字节开始,等于0x08c379a0。

**系统内部错误(Panic)**以keccak256(Panic(uint256))的前四个字节开始,等于0x4e487b71。

Panic 有一个额外的错误标识。目前可用的 Panic 有:

0x01: 使用 asset;

0x11: SafeMath 的溢出。

0x12: 除以 0。

0x21: 转换为不存在的枚举类型。

0x22: 存储字节数组编码错误。

0x31: 在一个空数组上pop()。

0x32: 索引超长度异常。

0x41: 分配过多的内存或创建过大的数组。

0x51: 调用未初始化的内部函数类型的变量。

拳皇泰森福瑞NFT在HoDooi以98.7万美元售出:据官方信息,Lineal by Tyson Fury以987000美元在HoDooi拍卖完成。这个价格打破了为NBA球星勒布朗詹姆斯扣篮支付的20万美元,以及购买克里斯蒂亚诺罗纳尔多NFT的30万美元。买家还将收到由Tyson Fury本人签名的5 x 5英尺的艺术品画作,以及签名的拳击手套和Fury 向获胜者祝贺他们中标的视频。[2021/7/20 1:04:24]

更多细节请参见文档中新的错误处理部分这里。

在大多数情况下,迁移应该是非常直接的。只有在一些情况下,你做奇怪的类型转换可能会变得更加困难。

你必须为迁移做出的改变包括:

ABIEncoderV2现在是默认自动激活。从 0.6 开始,Encoder 就不再是实验性的了,只是因为遗留的原因,保留了 pragma experimental这个名字。现在你不需要再加这行了。

移除任何 Openzeppelin SafeMath,你不再需要它了。

可能需要进行一些类型转换。

msg.sender和 tx.origin默认不属于 payable 类型。将 msg.sender.transfer改为 payable(msg.sender).transfer。

只有在符合给定类型的情况下,才允许类型转换,所以uint256(-1)将不再工作。使用type(uint256).max代替。

当多次改变符号时,类型转换在某些情况下会受到限制,因为类型转换的顺序可能会对结果产生影响。你现在会看到一个类似 TypeError 的错误。不允许从 int256到 bytes32进行显示的类型转换,得先手动转换为 uint256。

HyperGraph 挖矿和通证合约通过CertiK审计:据官方消息,HyperGraph 挖矿和通证合约日前通过了CertiK的审计,CertiK 对HyperGraph合约进行了审计,并就相关逻辑与开发团队进行了反复讨论和确认沟通。CertiK的报告也就某些逻辑的开发提出了很好的意见和改进建议,这对于团队后续的智能合约开发很有帮助。[2021/5/26 22:47:04]

修饰组合

myContract.functionCall{gas: 10000}{value: 1 ether }()改为:

myContract.functionCall{gas: 10000, value: 1 ether }()。

将 x**y**z改为(x**y)**z,因为默认的执行顺序改变了。

将 byte类型改为 byte1 。

我省略了一些细节,关于完整的变更日志和所有变更的细节,请查看文档这里。

来源:https://soliditydeveloper.com/solidity-0.8

登链翻译计划: https://github.com/lbc-team/Pioneer

翻译小组: https://learnblockchain.cn/people/412

Tiny 熊: https://learnblockchain.cn/people/15

Solidity0.8: https://blog.soliditylang.org/2020/12/16/solidity-v0.8.0-release-announcement/

0.7发布: https://blog.soliditylang.org/2020/07/28/solidity-v0.7.0-release-announcement/

Solidity 0.8 的文档: https://learnblockchain.cn/docs/solidity/

SafeMath: https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/math/SafeMath.sol

这里: https://medium.com/blockchannel/the-use-of-revert-assert-and-require-in-solidity-and-the-new-revert-opcode-in-the-evm-1a3a7990e06e

这里: https://docs.soliditylang.org/en/latest/control-structures.html#panic-via-assert-and-error-via-require

这里: https://docs.soliditylang.org/en/latest/080-breaking-changes.html

Cell Network: https://www.cellnetwork.io/?utm_souce=learnblockchain

译文出自:登链翻译计划

译者:翻译小组

校对:Tiny 熊

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

区块博客

ICP2.5早间行情:行情暂止涨 BTC本周难破40000美元

据OKEx的数据显示,当前BTC/USDT现货报价为37050美元,当日涨幅为1.31%。上涨了两天的行情迎来了终于休息,昨天下午冲击至38700美元附近时又快速回调,这次的回调幅度比前两天白天回调要更深一些,一度跌回36000美元附近,晚上反弹的最高点也未再次站上38000美元,看来38000美元还是有一定的压制作用。

欧易交易所金色早报 | 以太坊矿工1月份收入达8亿美元创历史新高

头条 ▌以太坊矿工1月份收入达8亿美元创历史新高 以太坊矿工1月份的收入达到了8亿美元,超过了三年前的历史最高纪录,此前的高点为2018年1月的7.62亿美元。The Block的Dashboard数据显示,以太坊1月份的挖矿收入中有超过3.11亿美元来自网络交易费用,占近40%。 矿工算力所带来的每日收入也达到2018年初以来的最高水平。

TRX区块链如何成为第三代互联网安全中重要一环?

原文标题:区块链与安全随想 有关区块链安全的话题很多,涉及到链上和链下。区块链自身的安全事件也层出不穷。但从宏观的角度而言,区块链技术本身给互联网和新的信息技术带了和很多安全上的保障。可以说,区块链是第三代互联网安全中的重要一环。

区块链数字人民币的精髓 都体现在它的钱包专利中了

前言:数字货币能否发挥其成效,技术路线、风险防控手段及安全保障措施固然是基础,但应用是关键。只有被公众和市场接受的、好用的法定数字货币才有生命力,才能真正实现对传统货币的补充或替代。数字人民币钱包作为数字时代人民币的重要流通载体和应用基础设施,其设计关乎数字人民币的成败。 本文系数字人民币钱包专利研究的先导篇,其他相关研究成果也将于近期推出,敬请期待。

[0:15ms0-7:964ms