【跟小嘉学 Rust 编程】一、Rust 编程基础
【跟小嘉学 Rust 编程】二、Rust 包管理工具使用
【跟小嘉学 Rust 编程】三、Rust 的基本程序概念
【跟小嘉学 Rust 编程】四、理解 Rust 的所有权概念
【跟小嘉学 Rust 编程】五、使用结构体关联结构化数据
【跟小嘉学 Rust 编程】六、枚举和模式匹配
本章节
主要教材参考 《The Rust Programming Language》
枚举允许您通过枚举其可能的变体来定义类型。使用 enum 关键字定义枚举类型。
#[allow(unused)]
#[derive(Debug)]
enum IpAddrKind {
V4,
V6,
}
枚举值使用 ::
获取
#[allow(unused)]
#[derive(Debug)]
enum IpAddrKind {
V4,
V6,
}
fn main() {
let ipv4 =IpAddrKind::V4;
let ipv6 = IpAddrKind::V6;
println!("{:?}", ipv4);
println!("{:?}", ipv6);
}
优点:
#[allow(unused)]
#[derive(Debug)]
enum IpAddrKind {
V4(u8,u8,u8, u8),
V6(String),
}
fn main() {
let ipv4 =IpAddrKind::V4(127,0,0,1);
let ipv6 = IpAddrKind::V6(String::from("::1"));
println!("{:?}", ipv4);
println!("{:?}", ipv6);
}
定义与标准库,用于描述一个值可能存在或者不存在的情况。在java或C/CPP之中存在有 NULL(表示空值),一个变量可能处于两种状态:空值(nulll)、非空。
可选枚举的定义
enum Option<T>{
Some(T),
None
}
它定义在 Prelude (预导入模块)中,可直接使用
fn main() {
let some_number = Some(5);
let some_string = Some(String::from("hello"));
let absent_number :Option<i32> = None;
}
当你要使用 None 来初始化变量的时候,不能省略类型。Option 要想与 T 类型数据参与运算 必须先转换为 T 类型。
enum Coin {
Penny,
Nickel,
Dime,
Quarter,
}
fn value_in_cents(coin: Coin) -> u8 {
match coin {
Coin::Penny => {
println!("lucky penny!");
},
Coin::Nickel => 5,
Coin::Dime => 10,
Coin::Quarter => 25,
}
}
匹配的分支可以绑定到被匹配对象的部分值,因此可以从 enum 变体中提取值
#[derive(Debug)]
enum UsState {
Alabama,
Alaska,
// --snip--
}
#[allow(unused)]
enum Coin {
Penny,
Nickel,
Dime,
Quarter(UsState),
}
fn value_in_cents(coin: Coin) -> u8 {
match coin {
Coin::Penny => 1,
Coin::Nickel => 5,
Coin::Dime => 10,
Coin::Quarter(state) => {
println!("State quarter from {:?}!", state);
25
}
}
}
fn main() {
let c = Coin::Quarter(UsState::Alaska);
println!("{:?}", value_in_cents(c));
}
Option
fn plus_one(x: Option<i32>) -> Option<i32> {
match x {
None => None,
Some(i) => Some(i+1),
}
}
fn main() {
let six = plus_one(Some(5));
let none = plus_one(None);
println!("{:?}", six);
println!("{:?}", none);
}
match 匹配到时候必须穷举所有的可能性,如果不匹配就会有错误,但是我们在使用 match 匹配的时候,会有存在的可能性比较多的情况,我们可以使用 _
来替代其余没列出的值
fn main() {
let x:u8= 1u8;
match x {
1=> println!("one"),
2=> println!("two"),
_=> ()
}
}
if let 控制流只关心一种匹配而忽略其他匹配的情况。
fn main() {
let config_max = Some(3u8);
if let Some(max) = config_max {
println!("The maximum is configured to be {}", max);
}
}
fn main() {
let config_max = Some(8u8);
if let Some(3) = config_max {
println!("three");
}else {
println!("others");
}
}
以上就是今天要讲的内容