60_模式匹配可辩驳性和基本语法

1. 概述

模式的两种形式包括:可辩驳的(可反驳的或可失败的)、无可辩驳的(不可反驳的或不可失败的)。

能够匹配任何可能传递的值的模式是无可辩驳的,即不能失败,怎么匹配都会成功。

  • 例如let x = 5不可能失败,它能匹配所有表达式右侧的值。

对于某些可能的值,无法进行匹配的模式,就是可辩驳的。

  • 例如if let Some(x) = a_value,如果右边的值是null,这时候就会发生不匹配的情况,这就是可辩驳的,或者可失败的。

其中,函数参数、let语句、for循环只接受无可辩驳的模式。if letwhile let接受可辩驳和无可辩驳的模式。在接受无可辩驳模式的时候编译器可能会发生警告,因为存在可能的失败。

如下例子:

rust 复制代码
fn main() {
    let a: Option<i32> = Some(5);
    // Some是个可辩驳的
    let Some(x) = a;
}

a是Option类型,而Some是一个可辩驳的,以上代码将会编译错误,可以修改为如下代码

rust 复制代码
fn main() {
    let a: Option<i32> = Some(5);
    if let Some(x) = a {

    }
}

但是如果我们改为不可辩驳的模式,如下

rust 复制代码
fn main() {
    let a: Option<i32> = Some(5);
    if let x = 5 {}
}

代码不会报错,但是x = 5总是匹配成功的,所以使用一个可辩驳的模式没有任何意义。结合上面的示例,我们可以想到match表达除了最后一个分支的所有分支必须是可辩驳的(即可失败的),而最后一个分支因为是不可辩驳的,因为它需要匹配所有剩余的情况。

相关推荐
Lee川1 天前
JavaScript 中的 `this` 与变量查找:一场关于“身份”与“作用域”的深度博弈
前端·javascript·面试
顺遂1 天前
基于Rokid CXR-M SDK的引导式作业辅导系统设计与实现
前端
代码搬运媛1 天前
Generator 迭代器协议 & co 库底层原理+实战
前端
前端拿破轮1 天前
从0到1搭建个人网站(三):用 Cloudflare R2 + PicGo 搭建高速图床
前端·后端·面试
功能啥都不会1 天前
PM2 使用指南 - 踩坑记录
前端
HelloReader1 天前
React 中 useState、useEffect、useRef 的区别与使用场景详解,终于有人讲明白了
前端
兆子龙1 天前
CSS 里的「if」:@media、@supports 与即将到来的 @when/@else
前端
踩着两条虫1 天前
AI 智能体如何重构开发工作流
前端·人工智能·低代码
代码老中医1 天前
逃离"Div汤":2026年,当AI写了75%的代码,前端开发者还剩什么?
前端
左夕1 天前
最基础的类型检测工具——typeof, instanceof
前端·javascript