rust - 如何在 Ok 时解包 Result 或在 Err 时从函数返回?

标签 rust

我有一个函数调用另一个返回Result 的函数。我需要检查 ResultOk 还是 Err,如果是 Err,我需要 return 尽早从我的函数中返回。这就是我现在正在做的:

match callable(&mut param) {
    Ok(_v) => (),
    Err(_e) => return,
};

是否有更惯用的 Rust 方法来做到这一点?

最佳答案

你可以创建一个宏:

macro_rules! unwrap_or_return {
    ( $e:expr ) => {
        match $e {
            Ok(x) => x,
            Err(_) => return,
        }
    }
}

fn callable(param: &mut i32) -> Result<i32, ()> {
    Ok(*param)
}

fn main() {
    let mut param = 0;
    let res = unwrap_or_return!(callable(&mut param));

    println!("{:?}", res);
}

请注意,我不建议丢弃错误。 Rust 的错误处理非常符合人体工程学,所以我会返回错误,即使它只是记录它:

fn callable(param: &mut i32) -> Result<i32, ()> {
    Ok(*param)
}

fn run() -> Result<(), ()> {
    let mut param = 0;
    let res = callable(&mut param)?;

    println!("{:?}", res);

    Ok(())
}

fn main() {
    if let Err(()) = run() {
        println!("Oops, something went wrong!");
    }
}

关于rust - 如何在 Ok 时解包 Result 或在 Err 时从函数返回?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54120500/

相关文章:

rust - 在使用 std::fmt 格式化时,如何用可变数量对数字进行 0 填充?

rust - 为什么 Rust 要求宏名称末尾有感叹号?

caching - 是否可以配置 Cargo 缓存它下载的 crate 的目录?

c++ - rust-bindgen 绑定(bind)引发 SIGSEGV

rust - 了解 "warning: use of ` #[推导 ]` with a raw pointer"警告

pointers - 原始指针没有产生预期的效果

rust - 双可变借用中的生命周期不匹配

syntax - 当我想引用一个枚举的变体时,是否有办法停止重复该枚举的名称? [复制]

rust - 在#[test]s 之间共享动态状态

rust - 如何创建类似函数的过程宏?