赞
踩
Rust中将错误分为两类:可恢复的错误和不可恢复的错误。当遇见不可恢复的错误时,直接使用panic!
宏使程序停止运行,当遇见可恢复的错误时,可以先使用枚举类型Result<T, E>
封装错误,然后利用match {}
对错误进行处理。在其它语言,比如Python
中,所有错误都是可恢复的错误,使用try except
对错误进行处理。
panic!
宏panic!
的使用方法就和println!
一样,如下:
fn main() {
let s = String::from("panic");
panic!("oh, {}", s);
}
// 报错信息
// thread 'main' panicked at 'oh, panic', src/main.rs:3:5
// note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
当执行到panic!
,会打印错误信息到屏幕上,然后清除栈空间(释放程序占用的资源),清理这一步骤需要时间,而且会增加编译后的可执行文件的体积,为了让程序直接退出,将资源回收的工作交给操作系统,可以在Cargo.toml
文件中增加:
[profile.release]
panic = 'abort'
这样,使用--release
构建的可执行文件在panic
时就会直接退出。
Result
枚举类型Result<T, E>
是枚举类型,由标准库定义,如下:
enum Result<T, E> {
Ok(T),
Err(E),
}
当执行某个操作可能失败时,比如使用File::open
函数打开文件时发现文件不存在,这时候并不希望程序停止运行,而是希望将这个错误返回给函数的调用者,让调用者决定如何处理。这时可以使用Result<T, E>
,当成功打开文件时,将文件句柄存放在Ok
中,当打开失败时,将错误信息存放在Err
中,代码如下:
use std::fs::File;
use std::io::Error;
fn main() {
let f: Result<File, Error> = File::open("hello.txt");
let f = match f {
Ok(file) => file,
Err(_) => panic!("cannot open file: 'hello.txt'"),
};
}
// 报错信息
// thread 'main' panicked at 'cannot open file: 'hello.txt'', src/main.rs:8:19
// note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
还是以打开文件为例,如果打开文件时提示文件不存在,那么可以先创建文件然后再打开,如果提示其它错误就直接panic
,代码如下:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。