如何处理 TcpStream 上的并行读写?

Posted

技术标签:

【中文标题】如何处理 TcpStream 上的并行读写?【英文标题】:How do I handle parallel reads and writes on a TcpStream? 【发布时间】:2014-12-24 15:35:12 【问题描述】:

我阅读了Idiomatic way to handle writes to a TcpStream while waiting on read,但我仍然不确定如何处理这个问题。我正在通过 Telnet 连接到 Rust 二进制文件,并想发送“命令”并接收“状态”。几乎就像一个简单的回显服务器。

【问题讨论】:

【参考方案1】:

我最终选择了cloning the stream,它运行良好:

let second_stream = stream.try_clone().expect("Cannot clone stream");
let mut reader = BufferedReader::new(second_stream);
let mut writer = BufferedWriter::new(stream);

【讨论】:

看起来很有线?【参考方案2】:

只是 Rust 1.1 的更新,此方法不再有效。为了完成这项工作,我在完成对服务器套接字的写入后使用了stream.shutdown(Shutdown::Write)。如果我必须从同一个连接重复读写,我不知道该怎么做。

【讨论】:

以上是关于如何处理 TcpStream 上的并行读写?的主要内容,如果未能解决你的问题,请参考以下文章

如何在Rust中读写XML到TcpStream?

如何处理mio中的错误?

17如何对字符串进行左, 右, 居中对齐 18如何去掉字符串中不需要的字符 19如何读写文本文件 20如何处理二进制文件 21如何设置文件的缓冲

与 MemoryMappedFile 并行读写

Rust 中如何处理分布式内存并行性? [关闭]

Pandas中如何处理大数据?