我迭代一个HashMap
并通过一些局部变量中的模式匹配将值放入其中。
委托人
fn lyrics_no_bottles(song_template:&mut String){
let mut template_partials = HashMap::new();
template_partials.insert("start", "No more bottles");
template_partials.insert("repeat", "no more bottles");
template_partials.insert("remaining", "99 bottles");
template_partials.insert("message", "Go to the store and buy some more");
resolve_template(song_template, template_partials);
}
打电话
fn resolve_template(song_template:&mut String, partials: HashMap<&str, &str>){
let start:&str;
let repeat:&str;
let remaining:&str;
let message:&str;
for key in partials.keys(){
match key {
"start" => start = partials.get(key),
"repeat" => repeat = partials.get(key),
"remaining" => remaining = partials.get(key),
"message" => message = partials.get(key)
}
}
*song_template = song_template.replace("%1", start);
*song_template = song_template.replace("%2", repeat);
*song_template = song_template.replace("%3", message);
*song_template = song_template.replace("%4", remaining);
}
错误输出
lib.rs:51:5: 58:6 error: type mismatch resolving `<std::collections::hash::map::Keys<'_, &str, &str> as core::iter::Iterator>::Item == &str`:
expected &-ptr,
found str [E0271]
lib.rs:51 for key in partials.keys(){
lib.rs:52 match key {
lib.rs:53 "start" => start = partials.get(key),
lib.rs:54 "repeat" => repeat = partials.get(key),
lib.rs:55 "remaining" => remaining = partials.get(key),
lib.rs:56 "message" => message = partials.get(key)
...
lib.rs:51:5: 58:6 help: run `rustc --explain E0271` to see a detailed explanation
lib.rs:53:32: 53:49 error: mismatched types:
expected `&str`,
found `core::option::Option<&&str>`
(expected &-ptr,
found enum `core::option::Option`) [E0308]
lib.rs:53 "start" => start = partials.get(key),
当我将参数声明为
&&str
时,我不明白为什么编译器认为存在HashMap<&str,&str>
。 最佳答案
因为that particular method returns a reference wrapped by an Option。
基本上,如果你在那里存储一个String
并使用get
。。您将得到一个Option<&String>
作为调用get
的结果。存储&str
将返回一个Option<&&str>
作为调用get
的结果。
值的示例以及在调用get
时它们的显示方式:
String -> Option<&String>
&str -> Option<&&str>
u32 -> Option<&u32>
当您将其作为值插入时,
&str
的所有权将被转移到hashmap。因此,hashmap使用get
返回对它们的引用。。。或mutable references using get_mut。操场现在坏了(不能分享任何东西)。。。所以这里有一个工作。。代码的分解示例:
use std::collections::HashMap;
fn main() {
let mut map: HashMap<&str, &str> = HashMap::new();
map.insert("start", "value");
let mut start: &str = "Unknown";
let mut repeat: &str;
let mut remaining: &str;
let mut message: &str;
for key in map.keys() {
match &key[..] {
"start" => start = map.get(key).unwrap(),
"repeat" => repeat = map.get(key).unwrap(),
"remaining" => remaining = map.get(key).unwrap(),
"message" => message = map.get(key).unwrap(),
_ => unreachable!()
}
}
println!("Result: {}", start);
}