火星链 火星链
Ctrl+D收藏火星链
首页 > AAVE > 正文

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

作者:

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

我们离Solidity1.0的发布越来越近了。Solidity0.8在0.7发布之后仅5个月就发布了!

登链社区正在同步翻译Solidity0.8的文档

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

尤达宝宝发布0.8新功能和如何使用

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

1.集成SafeMath

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

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

?transact?to?Solidity08.test?errored:?VM?error:?revert.?revert

韩国信用金融协会前官员金柱贤被任命为金融委员会委员长,将研究如何监管加密货币:金色财经报道,韩国信用金融协会前官员金柱贤被任命为尹锡烈政府的首任金融委员会委员长。他是金融服务委员会主席高升范的继任者,担任金融服务委员会主席的候选人金柱贤将承担重大责任,例如新政府下的家庭贷款法规的合理化以及基于金融稳定对小企业的金融支持。他的任务还有如何监管仍处于法律盲区的虚拟资产(加密货币)的。

6月7日,韩国总统尹锡烈提名韩国信用金融协会前官员金柱贤为部长级金融委员会主席人选。[2022/6/7 4:08:00]

但这种情况在未来应该会有所改变。

如果你确实就希望代码能够溢出呢?还是非常在意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;????}}

央行回应非指定机构如何参与数字人民币运营:央行表示,需发挥其他商业银行及非银行支付机构作用,与指定运营机构一起,共同提供数字人民币流通服务,包括支付产品设计创新、系统开发、场景拓展、市场推广等服务。(一财)[2021/7/16 0:57:56]

2.无效的操作码被还原取代

到目前为止,某些操作会导致INVALID操作码的执行。这个操作码的问题是,它消耗掉所有剩余的Gas。这显然是不好的且没必要。为什么要浪费Gas,把它捐给矿工?

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

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

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

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

Craig Wright:PoW是指导网络存在分歧时如何行动的信号:Craig Wright在其最新的博客文章中解释了为什么工作量证明(Proof-of-Work,PoW)是至关重要的。他表示,工作量证明是一种重要的信号,它告诉网络上的节点,当网络上存在分歧时,该如何行动。重要的是要区分这些节点不是对网络规则投票,而是执行规则。他说,“工作量证明是一种经济信号,从理论上讲是从游戏的角度去激励玩家的诚实行为,或者提供一种惩罚机制。”[2020/8/20]

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

0x01:使用asset;

0x11:SafeMath的溢出。

0x12:除以0。

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

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

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

0x32:索引超长度异常。

美国货币监理署新署长:期望进一步了解银行与加密货币机构如何相互作用:美国货币监理署(OCC)新署长Brian Brooks表示,OCC正寻求与银行和加密货币机构的行业领袖进行更多的对话,期望了解如何进一步促进双方相互作用。他表示加密货币机构需要银行服务,他们需要跨银行通道进行交易的。他期望进一步了解有关加密货币对银行的需求以及银行对加密货币的需求,因为他们确实想在这方面有所作为。OCC是美国财政部的主要银行监管机构,Brooks于3月份离开Coinbase,加入OCC并担任首席法律官。(Cointelegraph)[2020/6/5]

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

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

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

如何迁移到Solidity0.8

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

美国商品期货交易委员会公布关于如何定义加密货币已经交易完成的解释: 美国商品期货交易委员会(CFTC)已经公布了解释说明,关于如何定义加密货币已经从买方“交付”给了卖方。确认交付已经完成的的两个因素是:1. 客户有能力 (i)拥有和控制全部数量的商品,无论是以保证金,还是使用杠杆或其他融资购买,以及(ii)在交易之日起28内,自由地商业使用商品(在任何特定平台内外);以及2. 报价人及卖方(包括各自的关联方或与报价人或卖家合作的其他人士)不保留任何利益或控制任何以保证金,杠杆或其他融资方式购买的商品,在超过自交易日期起计28日后。据CFTC称,提议的解释不是最终的,需要经过90天的公众评议期。[2017/12/16]

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

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

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

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

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

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

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

修饰组合

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

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

将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/

Solidity0.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

CellNetwork:https://www.cellnetwork.io/?utm_souce=learnblockchain

译文出自:登链翻译计划

译者:翻译小组

校对:Tiny熊

标签:SOLLIDSOLIDDITsol币前景怎么样VSolidusSolidblockRadditarium Network

AAVE热门资讯
PAD:币安Launchpad开放SafePal(SFP)投入通道

亲爱的用户:币安Launchpad于2021年02月08日中午12:00开放SafePal投入通道,本次Launchpad采用全新投入模式,基于用户6日BNB日平均持仓进行投入.

1900/1/1 0:00:00
AAVE:AAVE成就千倍神话,牛市背景下如何取舍

最近,DeFi项目非常强势,再次给市场带来强烈的FOMO效应。LINK创下新高,AAVE突破500美元,寿司突破16美元,UNI突破20美元。优秀的项目太多了,已经在市场上涨服了不少人.

1900/1/1 0:00:00
SDT:BiONE关于对部分ETF产品合并的公告

尊敬的BiONE客户:由于当前部分ETF产品的单价均低于0.015USDT,为提高其价格变化的灵敏度,优化交易体验,BiONE将在2021年2月8日00:00-03:00期间.

1900/1/1 0:00:00
USD:币安合约调整爆仓清算率公告(2021-02-07)

亲爱的用户:为了更好地规范市场,币安将于2021年02月07日中午12:00调整U本位合约及币本位合约爆仓清算率.

1900/1/1 0:00:00
BIT:多个案例禁止加密货币与人民币结算 追回投资损失将更困难

吴说作者|火小律本期编辑|ColinWu****中国法院并没有否认比特币具有财产属性,但涉及到虚拟货币和法币的兑换、结算,都是政策所禁止的,并在近期开始执行落地.

1900/1/1 0:00:00
比特币:“CME效应”助以太坊突破1700美元

市值第二的加密货币以太坊周五继续强势上涨突破1700美元,日涨幅超6%。以太坊近期的上涨势头受计划于下周一在芝加哥商品交易所推出的以太坊期货影响.

1900/1/1 0:00:00