Rust 教程
- 第1节:Rust 介绍
- 第2节:Rust 安装
- 第3节:Rust Hello,world!
- 第4节:Rust Hello,Cargo!
- 第5节:Rust 栈和堆
- 第6节:Rust 测试
- 第7节:Rust 条件编译
- 第8节:Rust 文档
- 第9节:Rust 迭代器
- 第10节:Rust 并发性
- 第11节:Rust 错误处理
- 第12节:Rust 外部函数接口
- 第13节:Rust Borrow 和 AsRef
- 第14节:Rust 发布通道
- 第15节:Rust 变量绑定
- 第16节:Rust 函数
- 第17节:Rust 基本类型
- 第18节:Rust 注释
- 第19节:Rust if
- 第20节:Rust for 循环
- 第21节:Rust while 循环
- 第22节:Rust 所有权
- 第23节:Rust 引用与借用
- 第24节:Rust 生存期
- 第25节:Rust 可变性
- 第26节:Rust 结构体
- 第27节:Rust 枚举
- 第28节:Rust 匹配
- 第29节:Rust 模式
- 第30节:Rust 方法语法
- 第31节:Rust 向量
- 第32节:Rust 字符串
- 第33节:Rust 泛型
- 第34节:Rust 特征
- 第35节:Rust 降
- 第36节:Rust if let
- 第37节:Rust 特征的对象
- 第38节:Rust 闭包
- 第39节:Rust 通用函数调用语法
- 第40节:Rust 箱和模块
- 第41节:Rust “常量”和“静态”
- 第42节:Rust 属性
- 第43节:Rust type 别名
- 第44节:Rust 类型转换
- 第45节:Rust 关联类型
- 第46节:Rust 全类型
- 第47节:Rust 操作符和重载
- 第48节:Rust 'Deref'强制转换
- 第49节:Rust 宏命令
- 第50节:Rust 原始指针
- 第51节:Rust unsafe
Rust 枚举
枚举
在 Rust 中枚举是一个类型,它表示几个可能变量中的一个数据:
enum Message {
Quit,
ChangeColor(i32, i32, i32),
Move { x: i32, y: i32 },
Write(String),
}
每个变量可以选择性的有与之关联的数据。定义变量的语法与之前定义结构体的语法类似:你可以有不包含数据的变量(如 unit-like 结构体),已经命名数据的变量,和未命名数据的变量(如数据结构体)。然而,不同于单独的结构体定义,枚举是一种类型。枚举的值可以与任何变量匹配。为此,一个枚举有时被称为‘总和类型’:这个枚举的可能值的集合是每个变量的可能值的集合的总和。
我们使用 :: 语法来使用每个变量的名称:它们由枚举本身的名字来划分作用域。这允许以下的代码实现:
let x: Message = Message::Move { x: 3, y: 4 };
enum BoardGameTurn {
Move { squares: i32 },
Pass,
}
let y: BoardGameTurn = BoardGameTurn::Move { squares: 1 };
这两个变量都被命名为 Move,但是由于它们局限于枚举的名称,它们可以无冲突使用。
一个枚举类型的值包含它是哪个变量的信息,不包括与该变量相关联的任何数据。它有时被称为‘标签结合’,因为数据中包括一个‘标签’用来指示数据的类型。编译器使用这些信息来保证你访问枚举中的数据的安全性。例如,你不能简单的就好像它是可能变量之一一样来尝试解构一个值:
fn process_color_change(msg: Message) {
let Message::ChangeColor(r, g, b) = msg; // compile-time error
}
不支持这些操作可能会看起来相当受限制,但是这是一个我们可以克服的限制。这里有两种方式:通过我们自己实现相等,或者通过模式匹配带有模式表达式的变量,你将在下一节中学习这些内容。我们对于 Rust 怎样实现平等了解还不够,但是我们会在特性章节学习到。