为什么我仍然可以使用`move`闭包捕获的变量?

时间:2019-01-23 00:02:41

标签: rust

我编写了一个Rust程序,该程序生成所有小写英文字母(“ aa”,“ ab”,...,“ zy”,“ zz”)的两个字母的排列:

fn main() {
    static ASCII_LOWER: [char; 26] = [
        'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',
        'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'
    ];

    let x: Vec<_> = ASCII_LOWER.iter().flat_map(|a| {
        let result = ASCII_LOWER.iter().map(move |b| {
            format!("{}{}", a, b)
        });

        dbg!(a);  // <--- How can `a` still be used?

        result
    }).collect();

    dbg!(x);
}

我需要将内部闭包标记为move,因为否则捕获的a借用寿命不长。但是,在这种情况下,我不知道此move的实际作用。关闭后,我仍然可以使用amove在这里实际上做什么?

1 个答案:

答案 0 :(得分:7)

  

move在这里实际上做什么?

它将变量移到闭包中。

  

关闭后我仍然可以使用a

a是实现&'static char的{​​{1}}。值移动后,编译器会自动插入该值的副本。

另请参阅: