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

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

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

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

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

if-else

Solana 1.9.15主网测试版本已发布:4月10日消息,区块链软件公司Laine发推称,Solana 1.9.15版本已经发布主网测试版,此版本修复了一个非常重要的问题,该问题可能导致了最近网络性能的下降。

解决机器人垃圾邮件和拥塞问题的另一个主要发展仍然是QUIC网络层的部署。这仍然处于非常积极的开发和测试中,但上线主网时间未知。[2022/4/10 14:15:59]

for 循环

while 循环

币安Labs宣布对Solv协议进行战略投资,将合作推出NFT:1月27日消息,币安Labs宣布对Solv协议进行战略投资。作为投资的一部分,币安Labs和Solv Protocol将合作在币安NFT市场上推出NFT,并帮助币安Labs投资组合公司发行金融NFT。

据悉,SolvProtocol是一个用于创建、管理和链上交易金融NFT的去中心化平台,已与30多个DeFi项目合作。Solv正准备推出融资工具“ConvertibleVoucher”,可帮助DAO通过利用原生代币获得流动资产,同时将清算风险降至最低。[2022/1/28 9:18:07]

do-while 循环

Solv Vouchers创始人发起有关新数字资产标准VNFT的提案EIP- 3525:官方消息,DeFi协议SolvVouchers创始人WillWang向以太坊社区发起EIP-3525提案,提出一种新的数字资产标准VersatileNFT(简称VNFT)。据提案介绍,VNFT是ERC721的拓展形式,通过为NFT资产添加数量属性使NFT成为半匀质化通证(semi-fungibletoken),具备拆分、合并、部分转让等能力,并仍可与现有的ERC721基础设施兼容。该提案目前处于草案状态。[2021/7/8 0:35:42]

三元运算符

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

以太坊开发者发布Solidity编程语言0.7.0版本:以太坊开发者发布Solidity编程语言0.7.0版本。官方表示,Solidity 0.7.0是对Solidity语言和编译器的重大更新。该版本删除了外部存储映射功能、关键词“var”、并且构造函数不再需要默认可见性(Visibility),另外还进行了一些语法更改。官方建议升级所有代码以使其与Solidity v.0.7.0兼容。[2020/7/29]

另外还有 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

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

银河链

FTX一文读懂跨链赛道的繁荣与可持续性

前言 人自诞生即有需求,随着各类群体与社会体系的组建,需求也由个人上升到了群体之间,从而又推动了社会的进化。早期人类社会,群体与群体之间想要产生联系以便解决群体需求需要路。遇到河流湖泊,绕行的时间和金钱成本过大促使人们发明了桥.

[0:15ms0-1:700ms