挖掘 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 -- 文件读写的主要内容,如果未能解决你的问题,请参考以下文章

Rust高并发读写

如何在Rust中读写XML到TcpStream?

python 包含汉字的文件读写之每行末尾加上特定字符

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

文本挖掘——准备文本读写及对Map操作的工具类

PHP4-漏洞挖掘思路