Rust的迭代器——collect
概述: 它能够将一个迭代器转换为各种集合类型,例如向量、哈希集、哈希映射等,能够将迭代器的所有元素收集到一个集合中
常见的用法:
将迭代器转换为Vec:
1 |
|
将迭代器转换为HashSet:
1 |
|
将迭代器转换为HashMap:
1 |
|
collect的类型推导:
collect是泛型的,通常需要通过上下文推导出类型目标,但是有时,如果没有足够的上下文,rust无法推导出目标类型,可能需要显式指定。
1 |
|
内部工作原理:
collect之所以通用,是因为它依赖于FromIterator trait,该trait定义了如何从一个迭代器构建某个集合类型。Vec、HashMap、HashSet等类型都实现了FromIterator
FromIterator定义如下:
1 |
|
常见的使用场景:
可以使用filter_map结合collect,从一个可能包含None的迭代器中收集有效的值
1
2
3let values = vec![Some(1), None, Some(2), Some(3)];
let result: Vec<i32> = values.into_iter().filter_map(|x| x).collect();
println!("{:?}", result); // 输出: [1, 2, 3]去重和排序:将元素收集到HashMap中去重,再收集到Vec来排序
1
2
3
4
5
6
7use std::collections::HashSet;
let vec = vec![3, 1, 2, 1, 3, 4];
let mut set: HashSet<_> = vec.into_iter().collect();
let mut vec: Vec<_> = set.into_iter().collect();
vec.sort();
println!("{:?}", vec); // 输出: [1, 2, 3, 4]将字符迭代器收集为字符串:
1
2
3let chars = vec!['R', 'u', 's', 't'];
let s: String = chars.into_iter().collect();
println!("{}", s); // 输出: Rust
性能考虑:
collect通常是高效的,因为它能够预知迭代器的大小并进行优化,提前分配足够的空间,避免不必要的内存重新分配。此外,对于较大的数据集,rust还可以通过并行化迭代器(rayon crate)来进一步提升性能。
Rust的迭代器——collect
http://example.com/2024/10/05/rust的迭代器——collect/