Solidity极简入门第十讲:控制流、用solidity实现插入排序_SOLID:BLID

这一讲,我们将介绍solidity中的控制流,然后讲如何用solidity实现插入排序,一个看起来简单,但实际上很容易写出bug的程序。

我最近在重新学solidity,巩固一下细节,也写一个「Solidity极简入门」,供小白们使用,每周更新1-3讲。

所有代码和教程开源在github:github.com/AmazingAng/WTFSolidity

这一讲,我们将介绍solidity中的控制流,然后讲如何用solidity实现插入排序,一个看起来简单,但实际上很容易写出bug的程序。

控制流

Solidity的控制流与其他语言类似,主要包含以下几种:

Solana生态DeFi项目Mercurial将更名为Meteora,并进行代币重置:12月28日消息,Solana生态DeFi项目Mercurial将更名为Meteora,并用Meteora代币进行重置,以取代其MER代币,MER持有者将获得Meteora的新代币产品。其中在1亿枚Meteora代币的供应中,20%将流通并完全流动,而80%将交给DAO管理,旨在激发用户兴趣,建立市场信心,与FTX/Alameda保持距离。[2022/12/28 22:12:06]

if-else

Neon Labs计划于12月12日在Solana上推出EVM兼容网络主网:金色财经报道,Neon Labs 计划于 12 月 12 日在 Solana 上推出 EVM 兼容网络 Neon 主网,Neon Labs 创始人兼首席执行官 Marina Guryeva 表示,Neon 允许开发者直接迁移代码而无需使用 Rust 重写代码。Neon 主网上线后,Aave、Curve 等项目将部署至该网络。[2022/11/7 12:29:14]

for循环

while循环

DOGE过去24小时上涨近10%,市值超越Solana:金色财经报道,随着马斯克收购Twitter消息发酵,Meme Coin 狗狗币(DOGE)价格出现上涨,据Coingecko数据显示,本文撰写时DOGE价格已升至0.084894美元,过去24小时涨幅达到9.4%,过去7天涨幅达到42.6%。此外,当前DOGE市值达到11,533,808,288美元,超越Solana跻身加密货币市值规模排名第九位。[2022/10/29 11:53:59]

do-while循环

Solana生态借贷协议Jet Protocol发布V2测试版:8月9日消息,Solana生态借贷协议Jet Protocol发布V2测试版,已上线保证金系统Jet Margin、固定利率市场Jet Bond和固定期限市场。[2022/8/9 12:12:16]

三元运算符

三元运算符是solidity中唯一一个接受三个操作数的运算符,规则条件?条件为真的表达式:条件为假的表达式。此运算符经常用作if语句的快捷方式。

另外还有continue和break关键字可以使用。

用solidity实现插入排序

写在前面:

90%以上的人用solidity写插入算法都会出错。插入排序

排序算法解决的问题是将无序的一组数字,例如,从小到大一次排列好。插入排序是最简单的一种排序算法,也是很多人学习的第一个算法。它的思路很简答,从前往后,依次将每一个数和排在他前面的数字比大小,如果比前面的数字小,就互换位置。示意图:

插入排序

python代码

我们可以先看一下插入排序的python代码:

改写成solidity后有BUG!

一共8行python代码就可以完成插入排序,非常简单。那么我们将它改写成solidity代码,将函数,变量,循环等等都做了相应的转换,只需要9行代码:

那我们把改好的放到remix上去跑,输入。BOOM!有bug!改了半天,没找到bug在哪。我又去google搜」solidityinsertionsort」,然后发现网上用solidity写的插入算法教程都是错的,比如:SortinginSoliditywithoutComparison

正确的solidity插入排序

花了几个小时,在Dapp-Learning社群一个朋友的帮助下,终于找到了bug所在。solidity中最常用的变量类型是uint,也就是正整数,取到负值的话,会报underflow错误。而在插入算法中,变量j有可能会取到-1,引起报错。

这里,我们需要把j加1,让它无法取到负值。正确代码:

运行后的结果:

总结

这一讲,我们介绍了solidity中控制流,并且用solidity写了插入排序。看起来很简单,但实际很难。这就是solidity,坑很多,每个月都有项目因为这些小bug损失几千万甚至上亿美元。掌握好基础,不断练习,才能写出更好的solidity代码。

原文:《Solidity极简入门:10.控制流,用solidity实现插入排序》

来源:panews

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

金智博客

[0:31ms0-5:892ms