Rust可空类型Option

文章目录

Rust基础教程:初步所有权结构体和枚举类函数进阶泛型和特征并发和线程通信cargo包管理

Rust进阶教程:用宏实现参数可变的函数类函数宏

Option基础

在一些编程语言中,允许存在空值,但在Rust中并不建议这么做,而建议采取可空类型Option来实现。

Option是一个枚举类型的数据结构,可以理解为具体类型和空值的组合,其声明为

rust 复制代码
pub enum Option<T>{
    None,
    Some(T),
}

下面做一个简单的示例,用Option类型的返回值,来构造一个除法函数,并表示x/0这种问题

rust 复制代码
//op.rs
fn div_safe(x:f32, y:f32) -> Option<f32> {
    if y==0.0{ None } else{ Some(y/x) }
}

fn main(){
    println!("5/3={:?}", div_safe(5.0,3.0));
    println!("5/0={:?}", div_safe(5.0,0.0));
}

其输出结果为

rust 复制代码
>op.exe
5/3=Some(0.6)
5/0=None

模式匹配

如果没有Option,那么绝大多数程序员可能不会注意到返回值为空的情况,从而也就忘记处理这种情况,最终导致错误。而Option这种设计,目的就是倒逼程序员不得不对函数的返回结果做分类处理,从而把错误扼杀在编译之前。

所以,在实际使用时,需要把Option中的有效值提取出来,为此可使用match来对其进行匹配,为此新建一个函数,以打印div_safe的结果

rust 复制代码
fn div_print(x:f32, y:f32){
    match div_safe(x, y){
        Some(res) => println!("{}/{}={}", y, x, res),
        None => println!("input error")
    }
}

fn main(){
    div_print(5.0, 3.0);
    div_print(5.0, 0.0);
}

输出结果为

rust 复制代码
>op.exe
3/5=0.6
input error

通过match语句对Option进行匹配,好处是考虑全面,但很多情况下,返回值None其实没有必要处理,这时可用if let语句

rust 复制代码
fn div_print_valid(x:f32, y:f32){
    if let Some(res) = div_safe(x, y){
        println!("{}/{}={}", y, x, res)
    }
}

修改之后结果为

rust 复制代码
>op.exe
3/5=0.6

unwrap

Option类型内置了unwrap方法,其功能是提取非空值,而对空值进行报错。

rust 复制代码
fn main(){
    println!("5/3={:?}", div_safe(5.0,3.0).unwrap());
    println!("5/0={:?}", div_safe(5.0,0.0).unwrap());
}

结果如下,可见unwrap实际上并没有体现出Option类型的优势和特点。

rust 复制代码
5/3=0.6
thread 'main' panicked at 'called `Option::unwrap()` on a `None` value', op.rs:14:44
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
相关推荐
山茶花开时。40 分钟前
[SAP ABAP] 静态断点的使用
开发语言·sap·abap
纠结哥_Shrek40 分钟前
Java 有很多常用的库
java·开发语言
加油,旭杏2 小时前
【go语言】函数
开发语言·后端·golang
南玖yy2 小时前
C语言:结构体
c语言·开发语言
2501_903238652 小时前
自定义登录页面的Spring Security实践
java·后端·spring·个人开发
〖是♂我〗4 小时前
自定义数据集 使用scikit-learn中svm的包实现svm分类
开发语言·python
南玖yy4 小时前
C语言:整型提升
c语言·开发语言
iqay4 小时前
【C语言】填空题/程序填空题1
c语言·开发语言·数据结构·c++·算法·c#
lsx2024064 小时前
ECharts 样式设置
开发语言
一 乐4 小时前
基于vue船运物流管理系统设计与实现(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端·船运系统