链闻ChainNews:
Solidity是以太坊上最主流的函数修改器。本篇文章从技术角度展示了如何针对异常情况在代码层面进行详细分析,最后总结出异常情况最易出现的一些场景,并给出相对应的建议。
来源|矩阵数字经济智库作者|闫莺等
函数修改器
Solidity提供了一个函数修改器的特性。函数修改器与Python中的装饰器类似,可以在一定程度上改变函数的行为,比如可以自动在函数执行前检查参数是否合法。函数修改器是可以被继承的,同时可以被派生类覆盖重写。
下面代码展示了如何声明并使用函数修改器。
contractowned{functionowned(){owner=msg
数据:当前注册成为以太坊验证者需等待近一个月:5月15日消息,据wenmerge.com数据显示,当前注册成为以太坊验证者需等待约639小时(近27天),目前排队等待的验证者数量超4.9万。此外,目前等待退出的验证者数量约为50,等待时间约为40分钟。[2023/5/15 15:03:41]
addressowner;//这个合约定义了一个在派生合约中使用的函数修改器//";"指代被修改函数的函数体。//当这个函数执行前,先检查msg
}contractContractisowned{//从owned合约继承了onlyOwner函数修改器并且将其作用于close函数//确保了这个函数只有在调用者为合约创建者时才会生效functionclose()onlyOwner{selfdestruct(owner);}}
Helveteq宣布将在瑞士证券交易所上市比特币和以太坊ETP:金色财经消息,瑞士证券交易所(SIX Swiss Exchange)今天证实,Helveteq将上市两种新的加密ETP:Bitcoin Zero / BTCO2和Ether Zero / ETH2O。通过此次上市,Helveteq成为2022年加入SIX的第三家加密ETP发行机构。
至此,共有11家加密ETP发行方加入SIX。该平台上市了155个可交易的加密ETP。据悉,Helveteq成立于2021年,总部位于Pf?ffikon SZ。此外,该公司在瑞士的Zollikon设有办事处。(Finance Magnates)[2022/4/11 14:17:45]
下面代码进一步展示了函数修改器是如何接收参数的,函数修改器的参数可以是上下文中存在的任意变量组成的表达式。
以太坊 2.0合约质押数量突破978万ETH:3月2日消息,据欧科云链OKLink数据显示,当前以太坊2.0合约质押数量为9,785,792 ETH,近一周新增11.4万ETH;当前质押年化收益率约合5.09%。[2022/3/2 13:32:10]
contractpriced{//函数修改器可以接收参数modifiercosts(uintprice){if(msg
}}contractRegisterispriced,owned{mapping(address=>bool)registeredAddresses;uintprice;functionRegister(uintinitialPrice){price=initialPrice;}//这里需要payable修饰词,否则无法通过该方法转账以太币//函数修饰器costs接收参数price//使用costs修饰器确保registe函数在msg
以太坊未确认交易为142,416笔:金色财经消息,据OKLink数据显示,以太坊未确认交易142,416笔,当前全网算力为477.16TH/s,全网难度为6.42P,当前持币地址为60,293,284个,同比增加127,185个,24h链上交易量为2,570,943.5ETH,当前平均出块时间为13s。[2021/7/7 0:34:52]
functionchangePrice(uint_price)onlyOwner{price=price;}}
下面的例子展示了如何使用函数修改器实现一个重入锁机制。
contractMutex{boollocked;modifiernoReentrancy(){require(!locked);locked=true;;locked=false;}//这个函数使用了noReentrancy修改器,这保证了在f函数内部无法再次调用f函数//在执行return7时也执行了函数修改器中的locked=false语句functionf()noReentrancyreturns(uint){require(msg
动态 | 以太坊资产管理协议Melon Protocol发布 1.0 版本:以太坊上的资产管理协议 Melon Protocol 正式发布了 1.0 版本,该版本名为「ZAHREDDINO」,协议为去中心化金融领域的一个重要探索,可以让开发者在以太坊上通过智能合约设立自动监管并运营的投资基金,实现传统资产管理业务的去中心化运作。Melon Protocol 由注册在瑞士的 Melonport 公司开发,该公司成立于 2016 年,由前高盛交易员 Mona El Isa 创建。[2019/3/3]
}异常处理以太坊使用状态回退机制处理异常。如果发生了异常,当前消息调用和子消息调用产生的所有状态变化都将被撤销并且返回调用者一个报错信号。Solidity语言提供了两个方便的函数assert和require来检查条件,并且当条件不满足的时候抛出一个异常。assert函数通常用于检查变量和内部错误,require函数用于确保程序执行的必要条件是成立的。一个正常运行的程序不应该遇到assert和require失败,否则程序代码中一定存在需要修复的问题。revert函数和throw关键词会标识发生了错误并且回退当前的消息调用产生的状态改变。当前调用收到子消息调用产生的异常时会自动抛出,所以异常会一层层上浮直到最上层的根调用,代码会立刻终止执行并回退状态改变。但是,
}
一个assert类型的异常会在下述场景抛出:
访问数组越界,下标为负数或者超出长度。访问固定长度的bytesN越界,下标为负数或者超出长度。对0做除法或者对0取模,比如5/0,5%0。移位操作使用了一个负数做操作数。转换一个特别大的数或者负数到枚举类型变量。使用移位操作时给一个负数值。使用枚举时将过大值或赋值转为枚举类型变量。调用assert函数并且参数值为false。一个require类型的异常会在下述场景抛出:
调用throw。调用require并且参数值为false。发起一个消息调用,但是这个调用没有正常完成,比如Gas耗尽、被调用函数不存在或者函数本身抛出一个异常。使用new创建一个合约,但是和3中提到的原因一样构造函数没有正常完成。调用外部函数时指向一个不包含代码的地址。合约通过一个没有payable修辞词的函数接收以太币,包括构造函数和fallback函数。合约通过一个公开的访问函数接收以太币。.transfer()失败。在require类型的异常发生时会执行回退操作,对于一个assert类型的异常执行一个无效操作。在这两种情况下,以太坊虚拟机都会撤销所有的状态改变。这样做是因为发生了意料之外的情况,交易无法安全执行下去,为了保证交易的原子性,最安全的操作就是撤销该交易对状态造成的影响。
在编写合约代码时,我们需要合理使用assert和require来保证代码能够按我们预期的设计进行。
更多精彩内容,关注链闻ChainNews公众号,或者来微博**@链闻ChainNews**与我们互动!转载请注明版权和原文链接!
来源链接:mp.weixin.qq.com
本文来源于非小号媒体平台:
链闻研究院
现已在非小号资讯平台发布1篇作品,
非小号开放平台欢迎币圈作者入驻
入驻指南:
/apply_guide/
本文网址:
/news/3626956.html
以太坊ETH
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场
上一篇:
文摘|Schnorr签名:比特币的最新升级
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。