簡體   English   中英

如何插入 LinkedList 的 HashMap 解引用迭代器?

[英]How to insert into HashMap dereferenced iterator of LinkedList?

如何解決屏幕截圖上的問題? 我已經嘗試讓它可變,但這不是重點。 它可能是什么,如何擺脫它? 我將感謝代碼中的更改。

截屏: scr
(來源: i.ibb.co

let mut buf = vec![0 as u8; 4096];
for stream in listener.incoming() {
    match stream {
        Ok(mut stream) => {
            match stream.read(&mut buf) {
                Ok(size) => {
                    //Get List of names
                    let names: LinkedList<String> = serde_json::from_slice(&buf[..size])?;
                    for name in names.iter() {
                        if (*data).available.contains_key(&*name) {
                            //If file already exist just update Vec of IP
                            (*data)
                                .available
                                .get_mut(&*name)
                                .unwrap()
                                .push(stream.peer_addr().unwrap());
                        } else {
                            //In another case - adding file with first IP that share it
                            let mut v: Vec<SocketAddr> = Vec::new();
                            v.push(stream.peer_addr().unwrap());
                            (*data).available.insert(*name, v);
                        }
                    }
                }
                Err(_) => {
                    println!("An error occurred, {}", stream.peer_addr().unwrap());
                }
            }
        }
        Err(e) => {
            println!("Error: {}", e);
        }
    }
}

您確定要來自 JSON 解析器的LinkedList而不是Vec作為 output 嗎? 來自LinkedList文檔:

使用VecVecDeque幾乎總是更好,因為基於數組的容器通常更快,memory 效率更高,並且更好地利用 CPU 緩存。

要解決您的問題,您應該遍歷names而不是names.iter() 這將使列表在for循環后無法使用。 然后,您必須刪除代碼中的取消引用,即用&name代替“ &*name ”,用name代替*name 但是,您根本不應該寫&*name ,因為 &* &*name中的&*相互抵消。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM