2017-08-25 16:36:49 +08:00
|
|
|
|
# 一个 I/O 项目:构建一个命令行程序
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2021-06-03 12:26:20 +08:00
|
|
|
|
> [ch12-00-an-io-project.md](https://github.com/rust-lang/book/blob/main/src/ch12-00-an-io-project.md)
|
2017-03-02 23:36:03 +08:00
|
|
|
|
> <br>
|
2023-01-21 10:44:32 +08:00
|
|
|
|
> commit 02a168ed346042f07010f8b65b4eeed623dd31d1
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2017-04-05 23:13:49 +08:00
|
|
|
|
本章既是一个目前所学的很多技能的概括,也是一个更多标准库功能的探索。我们将构建一个与文件和命令行输入/输出交互的命令行工具来练习现在一些你已经掌握的 Rust 技能。
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2023-01-21 10:44:32 +08:00
|
|
|
|
Rust 的运行速度、安全性、单二进制文件输出和跨平台支持使其成为创建命令行程序的绝佳选择,所以我们的项目将创建一个我们自己版本的经典命令行搜索工具:`grep`。grep 是 “**G**lobally search a **R**egular **E**xpression and **P**rint.” 的首字母缩写。`grep` 最简单的使用场景是在特定文件中搜索指定字符串。为此,`grep` 获取一个文件路径和一个字符串作为参数,接着读取文件并找到其中包含字符串参数的行,然后打印出这些行。
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2023-01-17 11:38:33 +08:00
|
|
|
|
在这个过程中,我们会展示如何让我们的命令行工具利用很多命令行工具中用到的终端功能。读取环境变量来使得用户可以配置工具的行为。打印到标准错误控制流(`stderr`)而不是标准输出(`stdout`),例如这样用户可以选择将成功输出重定向到文件中的同时仍然在屏幕上显示错误信息。
|
2017-04-05 23:13:49 +08:00
|
|
|
|
|
2023-01-21 10:44:32 +08:00
|
|
|
|
一位 Rust 社区的成员,Andrew Gallant,已经创建了一个功能完整且非常快速的 `grep` 版本,叫做 `ripgrep`。相比之下,我们的版本将非常简单,本章将教会你一些帮助理解像 `ripgrep` 这样真实项目的背景知识。
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2018-01-22 10:34:33 +08:00
|
|
|
|
我们的 `grep` 项目将会结合之前所学的一些内容:
|
2017-03-02 23:36:03 +08:00
|
|
|
|
|
2019-12-08 23:28:53 +08:00
|
|
|
|
- 代码组织(使用 [第七章][ch7] 学习的模块)
|
|
|
|
|
- vector 和字符串([第八章][ch8],集合)
|
|
|
|
|
- 错误处理([第九章][ch9])
|
|
|
|
|
- 合理的使用 trait 和生命周期([第十章][ch10])
|
|
|
|
|
- 测试([第十一章][ch11])
|
|
|
|
|
|
2023-09-25 22:07:16 +08:00
|
|
|
|
另外还会简要的讲到闭包、迭代器和 trait 对象,它们分别会在 [第十三章][ch13] 和 [第十七章][ch17] 中详细介绍。
|
2019-12-08 23:28:53 +08:00
|
|
|
|
|
|
|
|
|
[ch7]: ch07-00-managing-growing-projects-with-packages-crates-and-modules.html
|
|
|
|
|
[ch8]: ch08-00-common-collections.html
|
|
|
|
|
[ch9]: ch09-00-error-handling.html
|
|
|
|
|
[ch10]: ch10-00-generics.html
|
|
|
|
|
[ch11]: ch11-00-testing.html
|
|
|
|
|
[ch13]: ch13-00-functional-features.html
|
2020-07-05 17:55:59 +08:00
|
|
|
|
[ch17]: ch17-00-oop.html
|