【Rust】迭代器(五)

环境

  • Time 2022-03-23
  • Rust 1.59.0

示例

find_map

fn main() {
    let vec = ["lol", "NaN", "2", "5"];
    let result: Option<i32> = vec.iter().find_map(|s| s.parse().ok());
    println!("{result:?}");
}

position

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result = vec.iter().position(|e| e > &2);
    println!("{result:?}");
}

rposition

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result = vec.iter().rposition(|e| e > &2);
    println!("{result:?}");
}

max

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result = vec.iter().max();
    println!("{result:?}");
}

min

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result = vec.iter().min();
    println!("{result:?}");
}

rev

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    vec.iter().rev().for_each(|e| println!("{e:?}"));
}

sum

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result: i32 = vec.iter().sum();
    println!("{result:?}");
}

product

fn main() {
    let vec = vec![0, 1, 2, 3, 4];
    let result: i32 = vec.iter().product();
    println!("{result:?}");
}

总结

了解了迭代器中相关的一些方法。

附录

posted @   jiangbo4444  阅读(50)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
历史上的今天:
2020-05-28 JavaWeb:Cookie
点击右上角即可分享
微信分享提示