30_result枚举与可恢复错误-上

1. 概述

通常情况下,错误都没有严重到要停止整个应用的地步。当某个函数运行失败,一般都有一些可以简单解释并做出可以做响应的原因所引起的,比如说我们程序想打开某个文件,但这个文件却不存在,这个时候通常是要创建该文件,而不是终止程序。在Rust里我们可以使用Result枚举类型,来处理可能失败的情况。该枚举类型的结构如下

Rust 复制代码
enum Result<T, E> {
    Ok(T),
    Err(E),
}

T:操作成功情况下,Ok变体里返回的数据类型 E:操作失败的情况下,Err变体里返回的错误的类型

2. 错误的处理

2.1 通常的处理方式

处理Result的一种方式:match表达式。和Option枚举一样,Result及其变体也是由prelude代码作用域。错误处理过程如下示例代码

Rust 复制代码
use std::fs::File;

fn main() {
    let f = File::open("hello.txt");

    let f = match f {
        Ok(file) => file,
        Err(error) => {
            panic!("Error opening file {:?}", error)
        }
    };
}

2.2 匹配不同的错误

可以在match里嵌套match,如下示例代码

Rust 复制代码
use std::fs::File;

fn main() {
    let f = File::open("hello.txt");

    let f = match f {
        Ok(file) => file,
        Err(error) => match error.kind() {
            // 文件不存在创建文件
            ErrorKind::NotFound => macth File::create("hello.txt") {
                Ok(fc) => fc,
                Err(e) => panic!("Error creating file: {:?}", e),
            },
            // 其他的错误类型,可以自定义变量名,这里叫做 other_error
            other_error => panic!("Error opening the file: {:?}", other_error),
        }
    };
}

我们可以使用unwrap_or_else方式实现以上代码实现的功能,如下示例代码

Rust 复制代码
use std::fs::File;

fn main() {
    let f = File::open("hello.txt").unwrap_or_else(|error| {
        if error.kind() == ErrorKind::NotFound {
            File::create("hello.txt").unwrap_or_else(|error| {
                panic!("Error creating file: {:?}", error);
            })
        } else {
            panic!("Error opening the file: {:?}", error);
        }
    });
}

2.3 unwrap和expect

unwrap可以被看作match表达式的一个快捷方法。如果Result的结果是OK,则返回OK的值,如果Result的结果是Err,则调用panic!宏。如下示例代码

Rust 复制代码
use std::fs::File;

fn main() {
    let f = File::open("hello.txt").unwrap();
}

我们还可以使用expect方法,改方法和unwrap类似,但可指定错误信息,如下示例代码

Rust 复制代码
let f = File::open("hello.txt").expect("无法打开文件");
相关推荐
想学后端的前端工程师18 小时前
【React性能优化实战指南:从入门到精通-web技术栈】
前端·react.js·性能优化
白兰地空瓶18 小时前
React Hooks 深度理解:useState / useEffect 如何管理副作用与内存
前端·react.js
cike_y18 小时前
JSP内置对象及作用域&双亲委派机制
java·前端·网络安全·jsp·安全开发
巴拉巴拉~~19 小时前
KMP 算法通用进度条组件:KmpProgressWidget 多维度 + 匹配进度联动 + 平滑动画
java·服务器·前端
子洋20 小时前
AI Agent 介绍
前端·人工智能·后端
徐同保20 小时前
使用n8n自动发邮件
前端
dly_blog20 小时前
setup 函数完整指南!
前端·javascript·vue.js
霍理迪20 小时前
基础CSS语法
前端·css
粟悟饭&龟波功21 小时前
【GitHub热门项目精选】(2025-12-19)
前端·人工智能·后端·github
流浪法师1221 小时前
MyPhishing-Web:AI 驱动的钓鱼邮件检测可视化平台
前端·人工智能