我正在尝试用async-std编写tcp服务器,为了解决读写借用检查的冲突,我发现了一个奇怪的方法:
use async_std::prelude::*;
use async_std::task;
use async_std::net::TcpListener;
use async_std::io::BufReader;
fn main() {
task::block_on(async {
let listener = TcpListener::bind("0.0.0.0:9000").await.unwrap();
let mut incoming = listener.incoming();
while let Some(stream) = incoming.next().await {
let stream = stream.unwrap();
println!("Client Addr: {:?}", stream.peer_addr().unwrap());
task::spawn( async move {
let (reader, mut writer) = (&stream, &stream); // Stange here <-----
let reader = BufReader::new(reader);
let mut lines = reader.lines();
while let Some(line) = lines.next().await {
let mut line = line.unwrap();
line.push('x');
line.push('\n');
writer.write_all(line.as_bytes()).await.unwrap();
}
});
}
});
}奇怪:let (reader, mut writer) = (&stream, &stream); // Stange here <-----我按照这个方法写了一个验证程序:
fn main() {
let mut arr = vec![1, 2, 3, 4];
let (r, mut w) = (&arr, &arr);
for v in r.iter() {
if v == &2 {
w.push(5);
}
}
dbg!(arr);
}获取错误:
error[E0596]: cannot borrow `*w` as mutable, as it is behind a `&` reference有人能解释一下吗?
发布于 2020-12-20 08:02:39
这之所以有效,是因为TcpStream具有以下隐式:
impl Read for TcpStream
impl Write for TcpStream
impl<'_> Read for &'_ TcpStream
impl<'_> Write for &'_ TcpStream前两个是“正常”的,后两个是“特殊的”,允许你做这个阅读器/写入器的把戏。
例如:read()特征方法定义如下:
pub fn read<'a>(&'a mut self, buf: &'a mut [u8]) -> ImplFuture<Result<usize>> 当您执行stream.read(buf)时,您正在使用impl Read for TcpStream impl。因此,您使用类型为&mut TcpStream的self调用该方法。
当您使用let reader = &stream; reader.read(buf)时,您使用的是impl<'_> Read for &'_ TcpStream。因此,您使用类型为&mut &TcpStream的self调用该方法。
https://stackoverflow.com/questions/65253855
复制相似问题