我的心态是让我String
的 s 保持不变,一个单一的事实来源。当我将同样的心态带入 Rust 时,我发现我必须做很多克隆。由于String
s 没有改变,所有的克隆都是不必要的。下面有一个例子和相关游乐场的链接。
借用似乎不是一种选择,因为我必须处理引用及其生命周期。我的下一个想法是使用类似Rc
或Cow
结构的东西。但是用类似的东西包裹所有的String
sRc
感觉不自然。在我有限的 Rust 经验中,我从未见过任何暴露的所有权/内存管理结构,即Rc
and Cow
. 我很好奇一个更有经验的 Rust 开发人员会如何处理这样的问题。
Rc
在 Rust 中公开所有权/内存管理结构,比如and是否真的很自然Cow
?我应该使用切片吗?
use std::collections::HashSet;
#[derive(Debug)]
enum Check {
Known(String),
Duplicate(String),
Missing(String),
Unknown(String)
}
fn main() {
let known_values: HashSet<_> = [
"a".to_string(),
"b".to_string(),
"c".to_string()]
.iter().cloned().collect();
let provided_values = vec![
"a".to_string(),
"b".to_string(),
"z".to_string(),
"b".to_string()
];
let mut found = HashSet::new();
let mut check_values: Vec<_> = provided_values.iter().cloned()
.map(|v| {
if known_values.contains(&v) {
if found.contains(&v) {
Check::Duplicate(v)
} else {
found.insert(v.clone());
Check::Known(v)
}
} else {
Check::Unknown(v)
}
}).collect();
let missing = known_values.difference(&found);
check_values = missing
.cloned()
.fold(check_values, |mut cv, m| {
cv.push(Check::Missing(m));
cv
});
println!("check_values: {:#?}", check_values);
}