# if let
> [if-let.md](https://github.com/rust-lang/rust/blob/master/src/doc/book/if-let.md)
commit 797a0bd1c13175398aa0e2e45f6dbb61bcb8c329
`if let`允許你合并`if`和`let`來減少特定類型模式匹配的開銷。
例如,讓我們假設我們有一些`Option<T>`。我們想讓它是`Some<T>`時在其上調用一個函數,而它是`None`時什么也不做。這看起來像:
~~~
# let option = Some(5);
# fn foo(x: i32) { }
match option {
Some(x) => { foo(x) },
None => {},
}
~~~
我們并不一定要在這使用`match`,例如,我們可以使用`if`:
~~~
# let option = Some(5);
# fn foo(x: i32) { }
if option.is_some() {
let x = option.unwrap();
foo(x);
}
~~~
這兩種選項都不是特別吸引人。我們可以使用`if let`來優雅地完成相同的功能:
~~~
# let option = Some(5);
# fn foo(x: i32) { }
if let Some(x) = option {
foo(x);
}
~~~
如果一個[模式](#)匹配成功,它綁定任何值的合適的部分到模式的標識符中,并計算這個表達式。如果模式不匹配,啥也不會發生。
如果你想在模式不匹配時做點其他的,你可以使用`else`:
~~~
# let option = Some(5);
# fn foo(x: i32) { }
# fn bar() { }
if let Some(x) = option {
foo(x);
} else {
bar();
}
~~~
### `while let`
類似的,當你想一直循環,直到一個值匹配到特定的模式的時候,你可以選擇使用`while let`。使用`while let`可以把類似這樣的代碼:
~~~
let mut v = vec![1, 3, 5, 7, 11];
loop {
match v.pop() {
Some(x) => println!("{}", x),
None => break,
}
}
~~~
變成這樣的代碼:
~~~
let mut v = vec![1, 3, 5, 7, 11];
while let Some(x) = v.pop() {
println!("{}", x);
}
~~~
- 前言
- 貢獻者
- 1.介紹
- 2.準備
- 3.學習 Rust
- 3.1.猜猜看
- 3.2.哲學家就餐問題
- 3.3.其它語言中的 Rust
- 4.語法和語義
- 4.1.變量綁定
- 4.2.函數
- 4.3.原生類型
- 4.4.注釋
- 4.5.If語句
- 4.6.循環
- 4.7.所有權
- 4.8.引用和借用
- 4.9.生命周期
- 4.10.可變性
- 4.11.結構體
- 4.12.枚舉
- 4.13.匹配
- 4.14.模式
- 4.15.方法語法
- 4.16.Vectors
- 4.17.字符串
- 4.18.泛型
- 4.19.Traits
- 4.20.Drop
- 4.21.if let
- 4.22.trait 對象
- 4.23.閉包
- 4.24.通用函數調用語法
- 4.25.crate 和模塊
- 4.26.const和static
- 4.27.屬性
- 4.28.type別名
- 4.29.類型轉換
- 4.30.關聯類型
- 4.31.不定長類型
- 4.32.運算符和重載
- 4.33.Deref強制多態
- 4.34.宏
- 4.35.裸指針
- 4.36.不安全代碼
- 5.高效 Rust
- 5.1.棧和堆
- 5.2.測試
- 5.3.條件編譯
- 5.4.文檔
- 5.5.迭代器
- 5.6.并發
- 5.7.錯誤處理
- 5.8.選擇你的保證
- 5.9.外部函數接口
- 5.10.Borrow 和 AsRef
- 5.11.發布途徑
- 5.12.不使用標準庫
- 6.Rust 開發版
- 6.1.編譯器插件
- 6.2.內聯匯編
- 6.4.固有功能
- 6.5.語言項
- 6.6.鏈接進階
- 6.7.基準測試
- 6.8.裝箱語法和模式
- 6.9.切片模式
- 6.10.關聯常量
- 6.11.自定義內存分配器
- 7.詞匯表
- 8.語法索引
- 9.參考文獻
- 附錄:名詞中英文對照