如何解决截图问题?我已经尝试使其可变,但这不是重点。可能是什么,如何摆脱它?感谢代码中的更改。
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
吗?从锈的LinkedList文档:
几乎总是使用Vec或VecDeque代替LinkedList
要解决您的问题,您应该呼叫names.into_iter()
而不是names.iter()
。请注意,这将使列表在for循环后不可用。然后,您将必须删除代码中的取消引用,即用&name
代替“ &*name
”,用name
代替*name
。但是,您根本不应该写&*name
,因为&*name
中的&和*正在互相抵消。
编辑:正如注释中所指出的那样,对init_iter()的调用是多余的,因为循环本身隐式地调用了int_iter()。