在下面的示例中,有什么方法可以简化返回值(最初从此处复制):
use std::num::ParseIntError;
fn multiply(first_number_str: &str, second_number_str: &str) -> Result<i32, ParseIntError> {
let first_number = match first_number_str.parse::<i32>() {
Ok(first_number) => first_number,
Err(e) => return Err(e),
};
let second_number = match second_number_str.parse::<i32>() {
Ok(second_number) => second_number,
Err(e) => return Err(AnotherError::ParseError("error")),
};
Ok(first_number * second_number)
}
我的意思是:
use std::num::ParseIntError;
fn multiply(first_number_str: &str, second_number_str: &str) -> Result<i32, ParseIntError> {
let first_number = first_number_str.parse::<i32>()
.unwrap_or_return(|e| Err(e));
let second_number = second_number_str.parse::<i32>()
.unwrap_or_return(|e| Err(AnotherError::ParseError("error"));
Ok(first_number * second_number)
}
您正在寻找问号运算符,可能会与Result::or
或结合使用Result::or_else
,具体取决于用例的具体情况。
该代码示例可以重写为
use std::num::ParseIntError;
pub fn multiply(first_number_str: &str, second_number_str: &str) -> Result<i32, ParseIntError> {
let first_number = first_number_str.parse::<i32>()?;
let second_number = second_number_str.parse::<i32>().or_else(|e| Err(e))?;
// The closure in `or_else` could also return `Ok` or some different error with type `ParseIntError`.
// let second_number = second_number_str.parse::<i32>().or_else(|_e| Ok(27))?;
Ok(first_number * second_number)
}
如果你知道你要返回Ok
的or_else
,Result::unwrap_or
是比较合适的。查看其他类似方法Result
以查看提供的方法。
如果您
Err
要从返回or_else
,则使用map_err
代替可能更干净。unwrap_or
不从函数返回。unwrap_or_return
将失败作为“尽早返回”的目的之一。例如,如果一个
first_number
或second_number
一个无效,则尽早返回Ok(0)!@Omid关键是
?
运算符,它确实从函数返回。@SCappella不是。检查一下:play.rust-lang.org/…