rust实战系列 - 使用Iterator 迭代器实现斐波那契数列(Fibonacci )
2022/2/5 6:13:47
本文主要是介绍rust实战系列 - 使用Iterator 迭代器实现斐波那契数列(Fibonacci ),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
为什么是斐波那契数列
斐波那契数列十分适合用来实战rust的迭代器,算法也很简单,一目了然。这个例子可以用来学习Iterator的使用,十分适合刚学习了rust的迭代器章节后用来练练手。
代码实战
don't bb, show me the code
struct Fib(usize, usize); impl Fib { fn new() -> Fib { Fib(0, 1) } } impl Iterator for Fib { type Item = usize; fn next(&mut self) -> Option<usize> { *self = Fib(self.1, self.0 + self.1); Some(self.0) } } fn main() { let last = 20; println!("fib({}) result: {:?}", last, Fib::new().take(last).collect::<Vec<usize>>()); }
分解知识点
- 代码定义了一个名字为Fib的元组结构体(tuple structs)。因为我们的实现封装了实现细节,没必要定义一个具名结构体。
网上有给出其他定义了名称的结构体,个人觉得有点多余了。比如这样
struct Fibonacci { a: u64, b: u64, }
- 第二点就是如何实现Iterator,关键就两点,定义关联类型和实现next方法
impl Iterator for Fib { // 1. 定义关联类型为usize type Item = usize; // 2. 实现next方法,这里也是主要的逻辑 fn next(&mut self) -> Option<usize> { *self = Fib(self.1, self.0 + self.1); Some(self.0) } }
- 第三点是
*self = Fib(self.1, self.0 + self.1);
; self被定义为了可变引用(&mut), 这里*self 解引用为Fib类型。
另外一种写法
self = &mut Fib(self.1, self.0 + self.1);
上面定义了一个可变引用 &mut Fib 赋值给self,rust编译器直接提示
| 12 | self = &mut Fib(self.1, self.0 + self.1); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot assign to immutable argument error[E0716]: temporary value dropped while borrowed --> src\main.rs:12:21 | 11 | fn next(&mut self) -> Option<usize> { | - let's call the lifetime of this reference `'1` 12 | self = &mut Fib(self.1, self.0 + self.1); | ------------^^^^^^^^^^^^^^^^^^^^^^^^^^^^- temporary value is freed at the end of this statement | | | | | creates a temporary which is freed while still in use | assignment requires that borrow lasts for `'1`
提示借用了临时变量,临时变量会被丢弃掉。其实就是&mut Fib 只是一个可变借用,在被借用给self后就会马上失效了,self就会指向一个悬垂指针, rust编译器肯定不会让这种情况发生的(强行解释一波,欢迎打脸)。
所以正确的做法是直接让self获取新创建的Fib的所有权就行了。也就是*self = Fib(self.1, self.0 + self.1);
。
- 第四点是
Fib::new().take(last).collect::<Vec<usize>>()
。 这里直接在println宏里打印结果,编译器推断不出需要collect的类型,需要使用collect::标注。
除非是下面这种写法,编译器能自动推断出来
let result: Vec<usize> = Fib::new().take(last).collect(); println!("fib({}) result: {:?}", last, result);
总结
本文通过rust iterator来实现斐波那契数列,需要掌握一下要点
- 元组结构体写法
- 如何实现iterator trait
collect::<B>
帮助编译器推断类型
这篇关于rust实战系列 - 使用Iterator 迭代器实现斐波那契数列(Fibonacci )的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用