我的第一个想法是map
,Option
但我不能try!
从封闭内部使用。该match
声明看起来没有必要,但我不知道如何简化它。
fn example<T, E>(val: Option<Result<T, E>>) -> Result<Option<T>, E> {
Ok(match val {
Some(v) => Some(v?),
None => None
})
}
我的第一个想法是map
,Option
但我不能try!
从封闭内部使用。该match
声明看起来没有必要,但我不知道如何简化它。
fn example<T, E>(val: Option<Result<T, E>>) -> Result<Option<T>, E> {
Ok(match val {
Some(v) => Some(v?),
None => None
})
}
在 Rust 1.33 中,transpose()
它是稳定的,所以你可以直接调用它:
fn main() {
let x: Result<Option<i32>, ()> = Ok(Some(5));
let y: Option<Result<i32, ()>> = Some(Ok(5));
assert_eq!(x, y.transpose());
}
您可以使用Option::map_or()
:
val.map_or(Ok(None), |v| v.map(Some))