• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Rust基础 错误处理

武飞扬头像
zzzzzzelu
帮助1

错误处理

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() {

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgcjhca
系列文章
更多 icon
同类精品
更多 icon
继续加载