链闻ChainNews:
Solidity是以太坊上最主流的函数修改器。本篇文章从技术角度展示了如何针对异常情况在代码层面进行详细分析,最后总结出异常情况最易出现的一些场景,并给出相对应的建议。
来源|矩阵数字经济智库作者|闫莺等
函数修改器
Solidity提供了一个函数修改器的特性。函数修改器与Python中的装饰器类似,可以在一定程度上改变函数的行为,比如可以自动在函数执行前检查参数是否合法。函数修改器是可以被继承的,同时可以被派生类覆盖重写。
下面代码展示了如何声明并使用函数修改器。
contractowned{functionowned(){owner=msg
前1000以太坊巨鲸过去24小时加仓前10 Token排名,FTT跃升至第二:3月17日消息,据whalestats.com数据,前1000以太坊巨鲸地址在过去24小时加仓前10 Token中,ETH居首,FTT跃升至第二,NU、GRT、NEXO分别位列第五、第六、第七。[2022/3/17 14:02:18]
addressowner;//这个合约定义了一个在派生合约中使用的函数修改器//";"指代被修改函数的函数体。//当这个函数执行前,先检查msg
}contractContractisowned{//从owned合约继承了onlyOwner函数修改器并且将其作用于close函数//确保了这个函数只有在调用者为合约创建者时才会生效functionclose()onlyOwner{selfdestruct(owner);}}
以太坊期货未平仓合约接近15亿美元,创历史新高:金色财经报道,根据衍生品数据提供商Bybt的数据,以太坊期货未平仓合约正接近15亿美元,已创下14.6亿美元新高。[2020/8/7]
下面代码进一步展示了函数修改器是如何接收参数的,函数修改器的参数可以是上下文中存在的任意变量组成的表达式。
contractpriced{//函数修改器可以接收参数modifiercosts(uintprice){if(msg
}}contractRegisterispriced,owned{mapping(address=>bool)registeredAddresses;uintprice;functionRegister(uintinitialPrice){price=initialPrice;}//这里需要payable修饰词,否则无法通过该方法转账以太币//函数修饰器costs接收参数price//使用costs修饰器确保registe函数在msg
Cardano创始人Charles Hoskinson:请不要再称我为以太坊联合创始人:Cardano创始人、IOHK CEO Charles Hoskinson在推特表示,他不希望人们称他为以太坊联合创始人。“你们能不能称我为IOHK首席执行官和Cardano创始人?老实说,如果你们不停地提到E(以太坊),我就不会再接受采访了。”
他还表示,自己只在以太坊工作了6个月,而他的很多精力都花在IOHK。此前,他最近更改了Reddit用户名,以前使用ethereumcharles的昵称,新昵称是IOGCharles。( Cryptopotato)[2020/6/15]
functionchangePrice(uint_price)onlyOwner{price=price;}}
以太坊核心成员:Telegram上出现冒充我向人们索要加密货币的局:以太坊核心成员Hudson Jameson在Twitter发文表示,有人在Telegram上冒充我进行加密局,我从来不会在网上向任何人索要加密货币。[2020/3/15]
下面的例子展示了如何使用函数修改器实现一个重入锁机制。
contractMutex{boollocked;modifiernoReentrancy(){require(!locked);locked=true;;locked=false;}//这个函数使用了noReentrancy修改器,这保证了在f函数内部无法再次调用f函数//在执行return7时也执行了函数修改器中的locked=false语句functionf()noReentrancyreturns(uint){require(msg
动态 | 以太坊期货日交易量接近历史最高水平:金色财经报道,根据数据提供商Skew的数据,以太坊期货的每日累计交易量非常接近其2019年5月17日的历史最高水平,即54.5亿美元。2月27日以太坊期货的交易量为52亿美元。火币的交易额最高,为19亿美元。其次是OKEx,交易量为13亿美元。尽管交易量增加,但自2月25日以来,未平仓合约一直在下降。[2020/2/28]
}异常处理以太坊使用状态回退机制处理异常。如果发生了异常,当前消息调用和子消息调用产生的所有状态变化都将被撤销并且返回调用者一个报错信号。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签名:比特币的最新升级
中央财经大学法学教授邓建鹏今日发表《区块链监管的未来之路——深度思考》一文,文中就区块链监管给出了7点建议。他表示,其一,我们首先建议监管机构加强国际协作,强化国际监管.
据路透社报道,Facebook于5月2日在日内瓦注册了一家名为LibraNetworks的新公司。这与其内部缓慢推出加密货币项目相吻合,这也是该公司首次涉足区块链技术.
5月15日BCH升级遭到攻击,慢雾安全团队及时跟进,并在社区里注意到相关分析工作,通过交流将此分析文完整转载于此.
北京时间2019年05月07日,区块链安全公司Zeppelin对以太坊上的DeFi明星项目MakerDAO发出安全预警,宣称其治理合约存在安全漏洞,希望已锁仓参与投票的用户尽快解锁MKR提并出.
日本地方法院首次在「加密劫持」案件中对罪犯判刑。在10个县逮捕利用Coinhive软件实施非法行为的犯罪嫌疑人后,对这起案件作出了判决.
尊敬的BITKER用户:BITKER将于2019年3月19日16点正式开启GLX/USDT,GLX/BTC交易对。Globcoin''sGLX是一种稳定币,占世界经济的85%.