如何将变量的资源推入向量但使其保持活动状态

问题描述

我有一个问题,关于如何将变量 move 转换为向量但不破坏该变量,因为它必须在循环中重复使用。下面显示了我的意思:

type Letter = char;
type LetterSet = Vec<Letter>;

fn main() {
    let mut v = Vec::<LetterSet>::new();
    let mut letterset: LetterSet = LetterSet::new(); 

    for i in 0..5 {
        let a = (48 + i as u8) as char;
        letterset.push(a);
        if i % 2 == 1 {
            let b = (65 + i as u8) as char;
            letterset.push(b); 
        } else {
            let c = (97 + i as u8) as char;
            letterset.push(c);
        }
        v.push(letterset.clone());
        letterset.clear();
    }

    for letterset in v {
        for letter in letterset {
            print!("{} ",letter);
        }
        println!("");
    } 
}

上面的代码运行。但是,我想避免 clone in

        v.push(letterset.clone());
        letterset.clear();

因为 letterset 无论如何都会被清除。相反,我想将其内容移动到 v 中,但保持它的活动状态,因为 letterset 必须用于下一次迭代。

我尝试删除 .clone(),但显然这会导致“移动后借用”错误。我想知道怎么做,谢谢。

解决方法

为什么不在每次迭代时创建一个新的 LetterSet?移动 Vec 只是移动对堆的引用,它非常便宜。

如果您真的想重复使用相同的 var,您可以使用 std::mem::take 它将返回 Vec 并以其默认值(空 vec)替换原始变量 - 这具有相同的行为,因为您是每次都创建一个新的 Vec。

v.push(std::mem::take(&mut letterset));

您也可以跳过 .clear(),因为它已经是空的了。

,

您可以简单地将 letterset 初始化移动到内部循环中:

for i in 0..5 {
    let mut letterset: LetterSet = LetterSet::new(); 
    let a = (48 + i as u8) as char;
    letterset.push(a);
    if i % 2 == 1 {
        let b = (65 + i as u8) as char;
        letterset.push(b); 
    } else {
        let c = (97 + i as u8) as char;
        letterset.push(c);
    }
    v.push(letterset);
}

或者完全消除它:

for i in 0..5 {
    let a = (48 + i as u8) as char;
    let b = (65 + i as u8) as char;
    let c = (97 + i as u8) as char;
    v.push(vec![a,if i % 2 == 1 { b } else { c }]);
}