亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何有效地查找和插入HashMap?

如何有效地查找和插入HashMap?

如何有效地查找和插入HashMap?我想做以下幾點:查找aVec用于特定的密鑰,并將其存儲以供以后使用。如果不存在,則創建一個空Vec但仍然保留在變量中。如何有效地做到這一點?很自然,我想我可以match:use std::collections::HashMap;// This code doesn't compile.let mut map = HashMap::new();let key = "foo";let values: &Vec<isize> = match map.get(key) {     Some(v) => v,     None => {         let default: Vec<isize> = Vec::new();         map.insert(key, default);         &default    }};當我嘗試的時候,它給了我一些錯誤,比如:error[E0502]: cannot borrow `map` as mutable because it is also borrowed as immutable   --> src/main.rs:11:13    | 7  |     let values: &Vec<isize> = match map.get(key) {    |                                     --- immutable borrow occurs here ... 11 |             map.insert(key, default);    |             ^^^ mutable borrow occurs here ... 15 | }    | - immutable borrow ends here最后我做了這樣的事情,但我不喜歡它執行兩次查找的事實(map.contains_key和map.get):// This code does compile.let mut map = HashMap::new();let key = "foo";if !map.contains_key(key) {     let default: Vec<isize> = Vec::new();     map.insert(key, default);}let values: &Vec<isize> = match map.get(key) {     Some(v) => v,     None => {         panic!("impossiburu!");     }};有一個安全的方法嗎?match?
查看完整描述

2 回答

?
SMILET

TA貢獻1796條經驗 獲得超4個贊

您可以使用v.key()在表達式中default,然后它將獲得對該鍵的引用,因為它存在于hashmap中,因此您可以這種方式避免克隆。

查看完整回答
反對 回復 2019-06-29
  • 2 回答
  • 0 關注
  • 944 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號