火星链 火星链
Ctrl+D收藏火星链
首页 > UNI > 正文

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

作者:

时间:1900/1/1 0:00:00

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

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

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

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

if-else

数据:6月Solana链上NFT销售额超6500万美元,较上月增长逾50%:金色财经报道,据CryptoSlam出炉的6月链上NFT销售数据显示,6月Solana链上NFT销售额达到67,597,357.79美元(交易量为857,917笔),虽然该指标较5月份44,852,015.74美元增长了约50.7%,但相比于年初 1 月超1.5亿美元的链上NFT销售额仍有较大差距,跌幅超过57%。[2023/7/1 22:12:00]

for 循环

while 循环

质押解决方案Chorus One将在Solana上推出集成MEV的开源协议:2月8日消息,质押解决方案Chorus One将在Solana上推出集成最大可提取价值(MEV)的开源协议。该协议旨在成为一个开源的公共产品,准备由Solana验证节点集体采用,并通过一个额外的去中心化实体进行管理,或者独立运行。Chorus One为Solana开发的MEV版本协议目前处于原型阶段。(The Block)[2023/2/8 11:54:07]

do-while 循环

三元运算符

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

Solana或已推出其线下实体门店:7月25日消息,据Uniswap NFT产品负责人Scott在社交媒体透露,Solana已推出其线下实体门店,该门店位于美国纽约哈德逊广场商店。[2022/7/25 2:36:45]

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

写在前面:

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

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

基于Solana的DEX Orca融资1800万美元,Polychain、三箭资本领投:9月22日消息,基于Solana的去中心化交易所Orca宣布1800万美元A轮融资,Polychain、Placeholder、Three Arrows Capital领投,Sino Global、Collab+Currency、Coinbase Ventures和Solana Capital等参投。Orca将利用本轮融资资金为DEX建造资本效率高、用户友好的自动化做市商(AMM)。(Blockworks)[2021/9/22 16:58:46]

插入排序

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

标签:SOLDITLIDSOLIDsol币价格最新消息RADDITSOLIDSolidblock

UNI热门资讯
COI:金色早报 | 欧盟知识产权局更新NFT和虚拟商品商标申请指南

头条▌欧盟知识产权局更新NFT和虚拟商品商标申请指南金色财经报道,为应对包含虚拟商品和NFT相关术语的商标申请的突然增加.

1900/1/1 0:00:00
MEV:流动性质押衍生品多存在卡特尔化和滥用MEV等风险

原文作者: ?Ethereum创作者:Xinyang@DAOrayaki.org原文: ?The Risks of LSD流动性质押衍生品(LSD)如 Lido 和类似协议是卡特尔化的一种表现.

1900/1/1 0:00:00
ISC:使DAO 保持粘性的四个因素

关注什么以及如何留住贡献者对“传统”员工满意度的研究反复表明,工作中有五个关键因素:任务享受、对任务重要性的理解、人员、反馈文化和成长机会。在 DAO 中并没有太大的不同.

1900/1/1 0:00:00
比特币:金色图览 | NFT交易市场TOP3周报(10.2 - 10.8)

【1002 - 1008】周报概要:1、上周 NFT 市场成交量有所回落,较上周下降约 -11.0%;其中 X2Y2 周成交额占比 36.3%.

1900/1/1 0:00:00
TIC:迪士尼乐园:未来的元宇宙

“只要世界上还有想象力存在,迪士尼乐园就永远不会完工。”华特·迪士尼在首座乐园即加州迪士尼乐园开园致辞时说。当我在迪士尼乐园的历史中寻找对未来元宇宙的借鉴时,这句话抓住了我.

1900/1/1 0:00:00
比特币:金色早报 | 北京通州拟成立元宇宙产业基金

头条▌北京通州拟成立元宇宙产业基金3月5日消息,北京市通州区金融办官方公众号显示,近日,通州区政府近日印发了《关于加快北京城市副中心元宇宙创新引领发展的若干措施》.

1900/1/1 0:00:00