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("无法打开文件");
相关推荐
西部荒野子3 分钟前
JS 如何跑进两个原生世界
前端
RANxy5 分钟前
AntV 入门系列第一篇:从零开始的数据可视化之旅
前端
小小小小宇36 分钟前
前端 WebRTC 全解析与应用
前端
华玥39 分钟前
优化滚动列表,使用虚拟滚动
前端
小小小小宇40 分钟前
前端 WebAssembly 全解析与应用
前端
huangdong_1 小时前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案
大数据·前端·数据库
尽兴-1 小时前
4.1 智能体核心:Agent、Sub-Agent、ReAct、规划执行
前端·javascript·react.js·agent·react·subagent
小小小小宇1 小时前
前端 Shadow DOM 全解析与应用
前端
万物更新_1 小时前
vue框架
前端·javascript·vue.js·笔记
小小小小宇1 小时前
前端 Web Workers 和 Service Workers 全解析与应用
前端