Rust语言入门教程(五) - 流控制语句

2023-11-26 12:15

本文主要是介绍Rust语言入门教程(五) - 流控制语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

if 表达式

在Rust中, if语句的判断条件不需要用( )括起来, 它会认为所有在if{之间的表达式就是判断条件,例如:

if num == 5 {msg = "five";
}

判断条件的表达式必须返回一个bool型的值, 因为Rust是一个不喜欢进行强制类型转换的语言,绝大多数时候, Rust都不会对数据进行强制类型转换,也就是说,下面的例子是一个错误的范例:

if 1 {msg = "five"
}

如果要进行多分支的条件判断,可以使用else if (注意 elseif是分开的),最后也可以用else结尾, 例如:

if num == 5{msg = "five";
} else if num == 4 {msg = "four";
} else {msg = "other";
}

注意, if是一种表达式, 而不是语句。 语句不会返回值, 而表达式会返回值, 因此,上面的代码可以改写成这样:

msg = if num == 5{"five"
} else if num == 4 {"four"
} else {"other"
};                // 注意, 这是一个赋值语句, 语句应以 ; 结尾

注意,在上面的例子中,每个判断分支的结尾没有, 因为这是一个尾部表达式, 用于给if表达式返回一个值;我们也不能使用return关键字, 而只能使用尾部表达式,因为return只能用于函数定义的代码块中,给函数返回结果;另外,每个判断分支返回的值的数据类型必须相同, 否则Rust编译器无法确定变量msg的数据类型; 在if表达式的最后有一个;, 因为整体来看, 这是一个赋值语句, 把if表达式的返回值赋值给了变量msg, 而Rust的语句应该以;结尾。

三元表达式?

Rust中没有三元表达式的设计, 例如在C语言中, 三元表达式形如:

num = a ? b : c;

虽然这种写法确实简单快捷, 但是即便这种简单的例子,其实也并不是特别易读和一目了然。如果事情稍微变得复杂一些, 加上一些三元表达式的嵌套, 看起来就更加的令人困惑了,比如:

num = a ? x ? y : z : c;

在Rust中我们选择抛弃三元表达式, 因为用if就已经能够简单的表达需求了, 比如:

num = if a {b} else {c};

即使存在一些嵌套也是比较简单易读的,

num = if a {if x {y} else {z}
} else {c
}

loop 循环

loop是无条件的循环, 与变量不可变的原因类似, Rust的这个设计的初衷, 也是考虑到编译器如果确定一个循环式无条件执行的情况下, 可以做更多的优化,从而获得更好的性能。

当然, 正如变量也需要改变,循环最终仍然是需要终结的。在Rust中,我们也使用break语句来跳出循环,例如:

loop {break;
}

但是如何跳出多层循环呢,比如:

loop {loop {loop {break;}}
}

默认情况下, 这只会跳出最内层的循环,如果我想跳出指定层级的循环应该怎么办呢?Rust允许我们给循环打标签,以便满足我们提到的这种需求, 标签的格式是'标签名(以一个'开头), 下面的例子展示了如何从让break语句跳出指定的循环:

'bob: loop {loop {loop {break 'bob;}}
}

最外层的循环被打上了一个名为'bob的标签, 而break 'bob语句告诉我们, 要跳出的正是这个'bob循环。与break的用法类型,continue语句通常用于跳过本次循环,进入到下一次循环, continue同样可以指定一个标签, 告诉代码下一次循环的入口在哪里, 例如:

'bob: loop {loop {continue 'bob;}
}

while 循环

while循环的行为和loop基本一致, 只是每次进行循环前, 都会进行条件判断, 当条件判断表达式的返回值为true时, 才会继续进行下一轮循环。 与if表达式的条件判断一样, 条件判断表达式的返回值必须为bool型, Rust不会为其他类型的返回值进行强制类型转换。格式如下:

while dizzy() {do_stuff()
}

用loop加上if, 也可以很容易的改写while表达式:

loop {if !dizzy() {break}do_stuff()
}

不要觉得这样做是不是因为我太无聊了,Rust中并没有do while的设计, 用上面的改写方法, 就可以轻松的实现do while的效果了:

loop {do_stuff()if !dizzy() {break}
}

for 循环

和大多数现代编程语言一样, Rust中的for循环会遍历一个可迭代对象中的每个值。复合数据类型和集合数据类型(collections)通常都会有一些方法来返回一个可迭代对象,用于for循环使用。

for num in [7, 8, 9].iter(){// do stuff with num
}

上面的例子中[7, 8, 9]这个数组调用了iter()函数来获取了一个迭代器,iter()这个函数也是通用的获取迭代器的方法。一些有序的数据类型的迭代器会有序的返回一组值, 但一些无序的数据类型的迭代器返回的值的顺序就是随机的了。

Rust的for循环中, 如果迭代器返回的是一组值, 那么for循环中也可以用一组变量来直接解构并接收返回的值,例如:

let a = [(1, 2), (3, 4)];
for (x, y) in a.iter() {// do stuff with x, y
}

还有一个常见的场景是在某个数字范围内进行for循环, 指定数字范围的格式是起始(闭)..结束(开)

for num in 0..50 {// do stuff with num 1 to 49
}

如果想要包含结束的数字, 那么可以用这种格式起始(闭)..=结束(闭)

for num in 0..=50 {// do stuff with num 1 to 50
}

小结

本章介绍了if条件判断语句, 和几种循环语句的格式和使用场景, 下一章将介绍Rust中比较重要的一种数据类型,String。

这篇关于Rust语言入门教程(五) - 流控制语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/425673

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

大语言模型(LLMs)能够进行推理和规划吗?

大语言模型(LLMs),基本上是经过强化训练的 n-gram 模型,它们在网络规模的语言语料库(实际上,可以说是我们文明的知识库)上进行了训练,展现出了一种超乎预期的语言行为,引发了我们的广泛关注。从训练和操作的角度来看,LLMs 可以被认为是一种巨大的、非真实的记忆库,相当于为我们所有人提供了一个外部的系统 1(见图 1)。然而,它们表面上的多功能性让许多研究者好奇,这些模型是否也能在通常需要系

人工和AI大语言模型成本对比 ai语音模型

这里既有AI,又有生活大道理,无数渺小的思考填满了一生。 上一专题搭建了一套GMM-HMM系统,来识别连续0123456789的英文语音。 但若不是仅针对数字,而是所有普通词汇,可能达到十几万个词,解码过程将非常复杂,识别结果组合太多,识别结果不会理想。因此只有声学模型是完全不够的,需要引入语言模型来约束识别结果。让“今天天气很好”的概率高于“今天天汽很好”的概率,得到声学模型概率高,又符合表达

C语言 将“China”译成密码

将“China”译成密码,密码规律是:用原来的字母后面的第4个字母代替原来的字母。例如,字母“A”后面的第4个字母是“E”,用“E”代替“A”。因此,“China”应译为“Glmre”。编译程序用付赋初值的方法使c1,c2,c3,c4,c5这五个变量的值分别为“C”,“h”,“i”,“n”,“a”,经过运算,使c1,c2,c3,c4,c5分别变成“G”,“l”,“m”,“r”,“e”。分别用put

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

【LinuxC语言】select轮询

文章目录 前言select函数详解selectfd_set类型一个小问题select函数使用步骤改进服务器代码select服务器示例代码 总结 前言 在Linux C语言编程中,我们经常需要处理多个I/O操作。然而,如果我们为每个I/O操作创建一个线程,那么当I/O操作数量增加时,线程管理将变得复杂且效率低下。这就是我们需要select轮询的地方。select是一种高效的I/

拓扑排序——C语言

拓扑排序(Topological Sorting)是一种用于有向无环图(DAG)的排序算法,其输出是图中所有顶点的线性排序,使得对于每条有向边 (u, v),顶点 u 在 v 之前出现。拓扑排序确定了项目网络图中的起始事件和终止事件,也就是顶点的执行顺序。         因为是有向无环图,所以拓扑排序的作用其实就是把先发生的排序在前面,后发生的排序到后面。 例如现在我们有一个

OC和 C语言中的const

const与宏对比 1.都是在其他的地方不可以改变 2.一个地方改了其他的地方都会改变。 而且宏定义的缺陷是, 是它会不断的开辟临时变量的存储空间 使用const的话 是都去使用同一的一份空间,使用同一个对象。 加const 之后变量还是全局的,只不过变为全局常量。 如果此时改变量不想被被类外面访问的话,可以加上static关键字, 3.下次想要定义一些宏的时候分

C语言入门系列:初识函数

文章目录 一,C语言函数与数学函数的区别1,回忆杀-初中数学2,C语言中的函数 二, 函数的声明1,函数头1.1,函数名称1.2,返回值类型1.3,参数列表 2,函数体2.1,函数体2.2,return语句 三,main函数四,函数的参数与传递方式1,实参和形参1.1,函数定义(含形参)1.2,函数调用(使用实参) 2,参数传递方式2.1,值传递2.2,引用传递 五,函数原型与预声明1,