gpt4 book ai didi

rust - 在等待读取时处理写入 TcpStream 的惯用方法

转载 作者:行者123 更新时间:2023-11-29 08:17:23 28 4
gpt4 key购买 nike

作为熟悉 Rust 和网络的一种方式,我开始编写一个非常基本的 telnet 聊天服务器。一切似乎都很顺利,但现在我遇到了不安全的代码块,我想知道是否有更好的方法来做事。

我生成了一个任务来监听与此类似的连接:Example TCP server written in Rust一旦用户连接并且我得到一个 TcpStream,我就把它放在一个 Connection 结构中。 Connection 结构使用 channel 与两个任务通信——一个用于从其 TcpStream 中读取,一个用于写入。读取任务阻塞在 TcpStream 的 read() 方法上,并将任何输入发送回 Connection 结构。 writer 阻塞在 Port 的 recv() 方法上,并将它接收到的任何内容写入 TcpStream。这样,程序的主循环就可以简单地维护一个连接结构向量来检查用户输入并随意写入。问题在于,对于此实现,TcpStream 必须由读写任务共享,并且在可变 read() 方法仍在其他任务中阻塞时调用可变 write() 方法。在 0.8 中,我用 Rc 和 unsafe_borrow_mut 做到了这一点,但如果可以的话,我想以更好的方式做到这一点——据我所知,在这种情况下,Rust 类型系统的反对意见可能是完全有效的。也欢迎对整体设计提出任何意见。谢谢。

最佳答案

目前没有惯用的方法可以做到这一点,因为 Rust 的 IO API 目前不支持并行读取或写入。有关详细信息,请参阅此问题:https://github.com/mozilla/rust/issues/11165将重新设计 TcpStream API 以允许以一种或另一种方式进行此类操作(请参阅问题),然后将提供一种“惯用方式”来执行此操作。

关于rust - 在等待读取时处理写入 TcpStream 的惯用方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21157789/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com