match
- 🌟🌟
// 填 空
enum Direction {
East,
West,
North,
South,
}
fn main() {
let dire = Direction::South;
match dire {
Direction::East => println!(“East”),
__ => { // 在 这 里 匹 配 South 或 North
println!(“South or North”);
},
_ => println!(__),
};
} - 🌟🌟 match 是一个表达式,因此可以用在赋值语句中
fn main() {
let boolean = true;
// 使 用 match 表 达 式 填 空 , 并 满 足 以 下 条 件
//
// boolean = true => binary = 1
// boolean = false => binary = 0
let binary = __;
assert_eq!(binary, 1);
} - 🌟🌟 使用 match 匹配出枚举成员持有的值
// 填 空
enum Message {
Quit,
Move { x: i32, y: i32 },
Write(String),
ChangeColor(i32, i32, i32),
}
fn main() {
let msgs = [
Message::Quit,
Message::Move{x:1, y:3},
Message::ChangeColor(255,255,0)
];
for msg in msgs {
show_message(msg)
}
}
fn show_message(msg: Message) {
match msg {
__ => { // 这 里 匹 配 Message::Move
assert_eq!(a, 1);
assert_eq!(b, 3);
},
Message::ChangeColor(_, g, b) => {
assert_eq!(g, __);
assert_eq!(b, __);
}
__ => println!(“no data in these variants”)
}
}
matches!
matches! 看起来像 match , 但是它可以做一些特别的事情 - 🌟🌟
fn main() {
let alphabets = [‘a’, ‘E’, ‘Z’, ‘0’, ‘x’, ‘9’ , ‘Y’];
// 使 用matches
填 空
for ab in alphabets {
assert!(__)
}
} - 🌟🌟
enum MyEnum {
Foo,
Bar
}
fn main() {
let mut count = 0;
let v = vec![MyEnum::Foo,MyEnum::Bar,MyEnum::Foo];
for e in v {
if e == MyEnum::Foo { // 修 复 错 误 , 只 能 修 改 本 行 代 码
count += 1;
}
}
assert_eq!(count, 2);
}
if let
在有些时候, 使用 match 匹配枚举有些太重了,此时 if let 就非常适合. - 🌟
fn main() {
let o = Some(7);
// 移 除 整 个match
语 句 块 , 使 用if let
替 代
match o {
Some(i) => {
println!(“This is a really long string and{:?}
”, i);
}
_ => {}
};
} - 🌟🌟
// 填 空
enum Foo {
Bar(u8)
}
fn main() {
let a = Foo::Bar(1);
__ {
println!(“foobar 持 有 的 值 是: {}”, i);
}
} - 🌟🌟
enum Foo {
Bar,
Baz,
Qux(u32)
}
fn main() {
let a = Foo::Qux(10);
// 移 除 以 下 代 码 , 使 用match
代 替
if let Foo::Bar = a {
println!(“match foo::bar”)
} else if let Foo::Baz = a {
println!(“match foo::baz”)
} else {
println!(“match others”)
}
}