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

问题描述 投票:-1回答:1

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

“屏幕截图:”“

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
1个回答
2
投票

首先,您确定要从JSON解析器输出LinkedList而不是Vec吗?从锈的LinkedList文档:

几乎总是使用Vec或VecDeque代替LinkedList

要解决您的问题,您应该呼叫names.into_iter()而不是names.iter()。请注意,这将使列表在for循环后不可用。然后,您将必须删除代码中的取消引用,即用&name代替“ &*name”,用name代替*name。但是,您根本不应该写&*name,因为&*name中的&和*正在互相抵消。

编辑:正如注释中所指出的那样,对init_iter()的调用是多余的,因为循环本身隐式地调用了int_iter()。

© www.soinside.com 2019 - 2024. All rights reserved.