![](/img/trans.png)
[英]how to implement an iterator that delegates to HashMap::values()
[英]How to insert into HashMap dereferenced iterator of LinkedList?
如何解决屏幕截图上的问题? 我已经尝试让它可变,但这不是重点。 它可能是什么,如何摆脱它? 我将感谢代码中的更改。
截屏:
(来源: 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
文档:
使用
Vec
或VecDeque
几乎总是更好,因为基于数组的容器通常更快,memory 效率更高,并且更好地利用 CPU 缓存。
要解决您的问题,您应该遍历names
而不是names.iter()
。 这将使列表在for
循环后无法使用。 然后,您必须删除代码中的取消引用,即用&name
代替“ &*name
”,用name
代替*name
。 但是,您根本不应该写&*name
,因为 &* &*name
中的&
和*
相互抵消。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.