切片模式

2018-08-12 22:03 更新

切片模式

如果用户希望匹配一个切片或数组,用户可以使用 & 来修饰 slice_patterns 功能。

#![feature(slice_patterns)]

fn main() {
let v = vec!["match_this", "1"];

match &v[..] {
["match_this", second] => println!("The second element is {}", second),
_ => {},
}
}

advanced_slice_pattern 使用户可以使用 .. 来表示切片匹配模式内部的元素任何数目。此通配符仅能为给定的数组使用一次。如果在 .. 前有个标识符,切片的结果将会绑定到这个名字。比如:

`#![feature(advanced_slice_patterns, slice_patterns)]

fn is_symmetric(list: &[u32]) -> bool {
    match list {
        [] | [_] => true,
        [x, inside.., y] if x == y => is_symmetric(inside),
        _ => false
    }
}

fn main() {
let sym = &[0, 1, 4, 2, 4, 1, 0];
assert!(is_symmetric(sym));

let not_sym = &[0, 1, 7, 2, 4, 1, 0];
assert!(!is_symmetric(not_sym));
} `
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号