|
|
|
@ -107,7 +107,7 @@ fn function2() -> IoResult<()> {
|
|
|
|
|
- `IoResult` 代表 `std:io::Result`
|
|
|
|
|
|
|
|
|
|
## 引入项再导出
|
|
|
|
|
当外部的模块项 `A` 被引入到当前模块中时,它的可见性自动被设置为私有的,如果你允许其它外部代码引入我们模块中的 `A`,那么可以对它进行再导出:
|
|
|
|
|
当外部的模块项 `A` 被引入到当前模块中时,它的可见性自动被设置为私有的,如果你希望允许其它外部代码引用我们的模块项 `A`,那么可以对它进行再导出:
|
|
|
|
|
```rust
|
|
|
|
|
mod front_of_house {
|
|
|
|
|
pub mod hosting {
|
|
|
|
@ -128,11 +128,11 @@ pub fn eat_at_restaurant() {
|
|
|
|
|
|
|
|
|
|
当你希望将内部的实现细节隐藏起来或者按照某个目的组织代码时,可以使用 `pub use` 再导出,例如统一使用一个模块来提供对外的 API,那该模块就可以引入其它模块中的 API,然后进行再导出,最终对于用户来说,所有的 API 都是由一个模块统一提供的。
|
|
|
|
|
|
|
|
|
|
## 使用三方包
|
|
|
|
|
之前我们一直在引入标准库模块或者自定义模块,现在来引入下三方包中的模块,关于如何引入外部依赖,我们在[Cargo入门](../../first-try/cargo.md#package配置段落)中就有讲,这里直接给出操作步骤:
|
|
|
|
|
## 使用第三方包
|
|
|
|
|
之前我们一直在引入标准库模块或者自定义模块,现在来引入下第三方包中的模块,关于如何引入外部依赖,我们在 [Cargo 入门](../../first-try/cargo.md#package 配置段落)中就有讲,这里直接给出操作步骤:
|
|
|
|
|
|
|
|
|
|
1. 修改 Cargo.toml 文件,在 `[dependencies]` 区域添加一行:`rand = "0.8.3"`
|
|
|
|
|
2. 此时,如果你用的是 `VSCode` 和 `rust-analyzer` 插件,该插件会自动拉取该库,你可能需要等它完成后,再进行下一步(VSCODE左下角有提示)
|
|
|
|
|
1. 修改 `Cargo.toml` 文件,在 `[dependencies]` 区域添加一行:`rand = "0.8.3"`
|
|
|
|
|
2. 此时,如果你用的是 `VSCode` 和 `rust-analyzer` 插件,该插件会自动拉取该库,你可能需要等它完成后,再进行下一步(VSCode 左下角有提示)
|
|
|
|
|
|
|
|
|
|
好了,此时,`rand` 包已经被我们添加到依赖中,下一步就是在代码中使用:
|
|
|
|
|
```rust
|
|
|
|
@ -143,10 +143,10 @@ fn main() {
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
这里使用 `use` 引入了三方包 `rand` 中的 `Rng` 特征,因为我们需要调用的 `gen_range` 方法定义在该特征中。
|
|
|
|
|
这里使用 `use` 引入了第三方包 `rand` 中的 `Rng` 特征,因为我们需要调用的 `gen_range` 方法定义在该特征中。
|
|
|
|
|
|
|
|
|
|
#### crates.io,lib.rs
|
|
|
|
|
Rust 社区已经为我们贡献了大量高质量的三方包,你可以在 `crates.io` 或者 `lib.rs` 中检索和使用,从目前来说查找包更推荐 `lib.rs`,搜索功能更强大,内容展示也更加合理,但是下载依赖包还是得用`crates.io`。
|
|
|
|
|
Rust 社区已经为我们贡献了大量高质量的第三方包,你可以在 `crates.io` 或者 `lib.rs` 中检索和使用,从目前来说查找包更推荐 `lib.rs`,搜索功能更强大,内容展示也更加合理,但是下载依赖包还是得用`crates.io`。
|
|
|
|
|
|
|
|
|
|
你可以在网站上搜索 `rand` 包,看看它的文档使用方式是否和我们之前引入方式相一致:在网上找到想要的包,然后将你想要的包和版本信息写入到 `Cargo.toml` 中。
|
|
|
|
|
|
|
|
|
|