区块见闻 区块见闻
Ctrl+D收藏区块见闻

DIT:Solidity极简入门第十讲:控制流、用solidity实现插入排序_Ripio Credit Network

作者:

时间:

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

我最近在重新学 solidity,巩固一下细节,也写一个「Solidity 极简入门」,供小白们使用(编程大佬可以另找教程),每周更新 1-3 讲。

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

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

if-else

for 循环

while 循环

do-while 循环

三元运算符

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

另外还有 continue(立即进入下一个循环)和 break(跳出当前循环)关键字可以使用。

写在前面:

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

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

插入排序

python 代码

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

改写成 solidity 后有 BUG!

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

那我们把改好的放到 remix 上去跑,输入 [2, 5, 3, 1]。BOOM!有 bug!改了半天,没找到 bug 在哪。我又去 google 搜」solidity insertion sort」,然后发现网上用 solidity 写的插入算法教程都是错的,比如:Sorting in Solidity without Comparison

正确的 solidity 插入排序

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

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

运行后的结果:

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

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

来源:panews

PANews

媒体专栏

阅读更多

金色早8点

Odaily星球日报

Bress

潘达看Web3

DeFi之道

区块律动BlockBeats

比推 Bitpush News

标签:SOLIDSOLLIDDITVSolidusInsolarBLID价格Ripio Credit Network

狗狗币最新价格热门资讯
加密货币:区块链存储四大优势不可不知_云存储币种

存储并不是个新词,随着互联网技术的快速发展,企业级存储、云存储等已成为人们工作生活的标配。与此同时,伴随区块链技术的发展与成熟,区块链存储的优势和特点开始受到多方关注.

比特币:区块链 数实融合的必然_有人靠区块链4天就挣了30万

当数字经济的浪潮汹涌而来,互联网的终极奥义,正在变得清晰。承载着庞大的流量,孕育着海量的新技术,数字经济,正在成为互联网的代名词.

区块链:又一知名虚拟货币企业高管被捕 定性_稳定币和加密货币哪个好

11月6日,徐州局官网发文《徐州“2021汉风3号”严打整治统一行动,48小时破获案件288起》引发关注.

LID:金色观察 | 史上最强“怨种”?Mango遭遇黑客“盗”“DAO”双击_MOSOLID

10月12日,Mango遭到了黑客的攻击,Mango在此次攻击损失总计约1.16亿美元,除此之外,Mango还遭受了黑客的另类攻击,通过提案来对Mango进行攻击.

ARK:我们研究了 ZK 的技术史 发现下一个千亿应用蕴藏其上_区块链工程专业学什么课程的

加密世界的焦点经历了比特币、以太坊、DeFi、NFT、元宇宙和Web3的多次变迁,唯独缺少对加密技术本身的关注,除了比特币的椭圆曲线加密算法(ECC)还算有一点大众认知度.

ARK:金色早报 | Huobi Global控股股东完成股份出售_ALI

金色财经报道,Huobi Global今天宣布,Huobi Global控股股东公司已向百域资本旗下基金转让所持有的全部Huobi Global股份.