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("无法打开文件");
相关推荐
tuokuac2 分钟前
nginx配置前端请求转发到指定的后端ip
前端·tcp/ip·nginx
程序员爱钓鱼5 分钟前
Go语言实战案例-开发一个Markdown转HTML工具
前端·后端·go
万少27 分钟前
鸿蒙创新赛 HarmonyOS 6.0.0(20) 关键特性汇总
前端
还有多远.1 小时前
jsBridge接入流程
前端·javascript·vue.js·react.js
蝶恋舞者1 小时前
web 网页数据传输处理过程
前端
非凡ghost1 小时前
FxSound:提升音频体验,让音乐更动听
前端·学习·音视频·生活·软件需求
吃饭最爱1 小时前
html的基础知识
前端·html
我没想到原来他们都是一堆坏人1 小时前
(未完待续...)如何编写一个用于构建python web项目镜像的dockerfile文件
java·前端·python
前端Hardy2 小时前
HTML&CSS:有趣的漂流瓶
前端·javascript·css
前端Hardy2 小时前
HTML&CSS :惊艳 UI 必备!卡片堆叠动画
前端·javascript·css