Kyl*_*and 12 foreach optional rust
我试图迭代一个字符串向量的子部分,即一个子部分Vec<String>
.在每次迭代中,我想将字符串作为切片传递给函数.
我没有注意到Vec::get
返回一个Option
,并认为我可以直接迭代返回值:
fn take_str(s: &str) {
println!("{}", s);
}
fn main() {
let str_vec: Vec<String> =
["one", "two", "three", "uno", "dos", "tres"].iter().map(|&s|
s.into()).collect();
for s in str_vec.get(0..3) {
take_str(&s); // Type mismatch: found type `&&[std::string::String]`
}
}
Run Code Online (Sandbox Code Playgroud)
显然,我期待s
成为一个String
,但事实上&[String]
.这是因为我的for循环实际上是迭代Option
返回的Vec::get()
.
我还编写了以下代码,它演示了for
循环实际上解开了Option
:
let foo = Option::Some ( ["foo".to_string()] );
for f in foo {
take_str(&f); // Same error as above, showing `f` is of type `&[String]`
}
Run Code Online (Sandbox Code Playgroud)
但这令人难以置信的混乱; 我没想到(直到我编写这段代码并弄清楚它实际上在做什么),Option
可以通过迭代来解开.为什么支持?有什么用例可以迭代Option
?
She*_*ter 14
有什么用例可以迭代
Option
?
总之,我最喜欢的理由是flat_map
:
fn main() {
let results = vec![Some(1), None, Some(3), None];
let sum: i32 = results.into_iter().flat_map(|x| x).sum();
println!("{}", sum)
}
Run Code Online (Sandbox Code Playgroud)
Option
可以被认为是一个可以容纳零个或一个元素的容器.将其与a进行比较Vec
,它可以容纳零个或多个元素.在大集的方式,一个Option
是集装箱就像一个Vec
!
实现IntoIterator
允许Option
参与更大比例的API.
请注意,IntoIterator
是还实施了Result
,出于同样的原因.
但这令人难以置信的混乱
是的,这就是为什么Clippy 有一个皮棉:
warning: for loop over `str_vec.get(0..3)`, which is an `Option`.
This is more readably written as an `if let` statement.
Run Code Online (Sandbox Code Playgroud)
这表明,有一些的办法Option
是不喜欢一个程序员的容器.
归档时间: |
|
查看次数: |
483 次 |
最近记录: |