挖掘 Rust -- 文件读写
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了挖掘 Rust -- 文件读写相关的知识,希望对你有一定的参考价值。
参考技术A注:因为 Rust 有些结构重名,读起来不容易理解,本文解释部分不会省略任何一个 std 命名空间
以行为单位读写文件
输出
std::io::prelude 是一个模块,包含了许多对 I/O 有用的 trait。不同于 std::prelude , std::io::prelude 需要被显示 use。
std::io::prelude 会导出如下 trait
补充,和本段无关
std::prelude 会导出如下内容
std::io::Result 是一个类型别名, std::io::Result 是一个类型别名,是一种专为 I/O 设计的 std::result::Result 。, std::io 中所有可能出错的函数都会用该类型返回结果。
type Result<T> = Result<T, Error>
因为 std::io 中的函数返回的错误类型总在 std::io::Error 这个枚举中,总是要写出 std::result::Result 显得繁琐。
std::result::Result 是会被 std::prelude 默认导出的(见上节),为了避免混淆,通常会 use std::io 然后用 io::Result 来指代 std::io::Result 。通过这种方式把它和 std::result::Result 区分开。
详见 std::io::ErrorKind
另一种常用的 Result 类型别名是 std::fmt::Result
直接调用 Read 实例上的读取函数效率比较低(比如,每次在 TcpStream 上的读取都会发起一个系统调用)。如果你想在内存中创建一个缓存区来加快读取效率的话,只需要用 BufReader::new 就能将一个实现了 Read 的实例转化为带有缓冲区的 BufReader 。
BufReader 是实现了 BufRead 这个 trait 的结构, BufRead 实现了一个 read_lines 方法。
与之对比的是, std::io::Read 中仅有 bytes 和 chars ,因而不能直接被用来以行为单位读取文件。
write! 宏用来向实现了 Write 这个 trait 的实体中写入格式化数据。
因为 impl Write for Vec<u8> 存在于 std::vec::Vec 中,我们也可以利用这个宏向其中写入数据。
注意 u8
存疑,我会在稍后确定答案后加在这里。
File 类型具有文件资源的所有权,当它离开作用域时,文件将被自动关闭。
如何处理 TcpStream 上的并行读写?
【中文标题】如何处理 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)
。如果我必须从同一个连接重复读写,我不知道该怎么做。
【讨论】:
以上是关于挖掘 Rust -- 文件读写的主要内容,如果未能解决你的问题,请参考以下文章