首页 > 解决方案 > 如何插入HashMap取消引用的LinkedList迭代器?

问题描述

如何解决屏幕截图上的问题?我已经尝试让它可变,但这不是重点。它可能是什么,如何摆脱它?我将感谢代码中的更改。

截屏: scr

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);
        }
    }
}

标签: rust

解决方案


您确定要 aLinkedList而不是 aVec作为 JSON 解析器的输出吗?从LinkedList文档:

使用它几乎总是更好,Vec或者VecDeque因为基于数组的容器通常更快,内存效率更高,并且可以更好地利用 CPU 缓存。

要解决您的问题,您应该循环names而不是names.iter(). 这将使列表在for循环后无法使用。然后,您必须删除代码中的取消引用,即写&name而不是 " &*name" 和name而不是*name. 但是,您根本不应该写&*name,因为in&*in&*name相互抵消。


推荐阅读