深圳查询建设项目规划的网站,做熊猫tv网站的目的,宣传视频怎么做吸引人,网上翻译网站做译员这篇文章是实战性质的#xff0c;也就是说原理部分较少#xff0c;属于经验总结#xff0c;rust对于模块的例子太少了。rust特性比较多#xff08;悲#xff09;#xff0c;本文的内容可能只是一部分#xff0c;实现方式也不一定是这一种。
关于 rust 模块的相关内容也就是说原理部分较少属于经验总结rust对于模块的例子太少了。rust特性比较多悲本文的内容可能只是一部分实现方式也不一定是这一种。
关于 rust 模块的相关内容准确来说怎么在源码中引用其他模块的内容。
关于 mod、 use 、as 这几个关键字文件名关于 mod.rs 文件关于 self、 super 、 crate 这几个路径关键字worksapce 本文不讨论狭义上指的是cargo的 [workspace] 部分 可参见 The [workspace] sectionpackage 狭义上指的是cargo的 [package] 部分参见 The [package] sectioncrate 参见下文 关于 create 的定义和 cargo 管理下的 cratemodule 本文的重点 crate 里 会有多个 module文本讨论重点就是 mod 之间相互引用的问题。
一、mod 关键字和 mod.rs 文件其他普通文件 foo.rs 等
引用模块要搞清楚的
是在哪里引用的也就要引用的文件的位置需要引用那个模块跟这个文件的相对位置和绝对位置是什么
mod 关键字
用来声明表现方式是包裹一个代码块。也就是说这个代码块会成为一个单独的模块。 mod xxx { rust语句块 } 内部写 rust 语句 。见 例一#[path...xxxx.rs] mod xxx; 使用 path 属性 使用见例二mod xxx { include!(...xxxx.rs) } 内部配合 include! 宏使用见例二用来声明“引用”其他“模块”。一个文件隐含的表示为一个mod 假设使用 mod toy; 语句来引入一个模块实际上这跟你在哪里写的这个语句有关系有关 把当前的文件所在位置分为两类 类型A位置在 src/main.rs、 src/lib.rs 或者 xxx/.../mod.rs 位置上的文件; 类型B: 位置不在1中的文件。在位置类型 A 的文件使用代码 mod toy;你实际上在告诉编译器你需要的模块是与此文件同级的 toy.rs 或者 toy/mod.rs文件 。编译器会自己找下这两个被引用的位置如果两个位置都有文件则报错。见 例三在位置类型 B 的文件使用代码 mod toy;你实际上在告诉编译器你需要的模块是与此文件假设文件名为 foo.rs同级的 foo 文件夹下的 foo/toy.rs 或者 foo/toy/mod.rs 文件。编译器会自己找下这两个被引用的位置如果两个位置都有文件则报错。 见 例四
二、使用 use 和 as 关键字缩短导入语句或者导出模块内容
use 关键字也有两个作用
缩短语句使用 use 为当前文件缩短长语句减少重复性的代码见 例子五配合 as 关键字一起使用进一步减少重复代码或者防止名字重复或者取个顺眼的名字 例子六打包其他模块的内容当做本模块的内容一起导出。见 例子七
三、使用 super 和 crate 进行相对路径和绝对路径顶级路径的访问
如果我们想要调用一个函数我们需要知道它的路径。路径有两种形式
绝对路径absolute path从 crate 根部开始以 crate 名或者字面量 crate 开头。 见例八相对路径relative path从当前模块开始以 self、super 或当前模块的标识符开头。
见文档 路径用于引用模块树中的项 - Rust 程序设计语言 中文版
四、关于 create 的定义和 cargo 管理下的 crate
我们都知道通过 cargo 创建出的工程中 src/main.rs 就是程序的入口但是还有更多的使用方式。
rustc 命令 rust编译器就算没有cargo也可以生成程序但是比较麻烦这些都让cargo来处理就好cargo 命令 项目管理工具
下面就是一些问题了
什么是 create rustc 的编译入口文件这个文件就被当做 crate 文件。crate 类型 有多种最常见的是 bin 和 lib其他类型参见 rust参考手册-链接cargo 怎么定义工程项目中哪些是需要编译的 crate 的 参见 cargo手册-项目布局
▾ src/ # 包含源文件的目录lib.rs # 库和包的主要入口点main.rs # 包生成可执行文件的主要入口点▾ bin/ # 可选包含其他可执行文件的目录*.rs▾ */ # 可选包含多文件可执行文件的目录main.rs
▾ examples/ # 可选示例*.rs▾ */ # 可选包含多文件示例的目录main.rs
▾ tests/ # 可选集成测试*.rs▾ */ # 可选包含多文件测试的目录main.rs
▾ benches/ # 可选基准*.rs▾ */ # 可选包含多文件基准的目录main.rs五、例子
例一单文件主函数和 toy 模块
注意 run 函数需要加 pub 关键字否则不会被导出
src/main.rs
mod toy {pub fn run() {println!(run toy);}
}fn main() {toy::run();
}输出
run toy例二两个文件主函数和另一个文件夹 toy 模块
src/toy_implements.rs
pub fn run() {println!(run toy_impl !);
}src/main.rs
mod toy1 { // 方法1 使用 include!include!(./toy_implements.rs);
}#[path ./toy_implements.rs]
mod toy2; // 方法2 使用 path 属性定位文件位置fn main() {toy1::run();toy2::run();
}输出
run toy_impl !
run toy_impl !例三在 main.rs 中使用 mod toy;
src/toy.rs
pub fn run() {println!(run toy_impl !);
}src/main.rs
mod toy;
fn main() {toy::run();
}输出
run toy_impl !例四在 src/foo.rs 中使用 mod toy;
src/foo/toy.rs
pub fn run() {println!(run toy_impl !);
}src/foo.rs
mod toy;
fn say_hi() {toy::run();
}输出
run toy_impl !例五use 指令
之前我们使用了 toy::run() 来调用 run 函数。现在我们使用 use 关键字来导入 toy 模块里的内容这样就能在 main 函数中直接使用
src/foo.rs
mod toy {pub fn run() { // 注意使用 pub 关键字println!(run toy);}
}
fn main() {use toy::*; // 使用 use 导入 toy 模块里的内容run(); // 直接调用
}例六 在as配合use指令
src/foo.rs
mod toy {pub fn run() { // 注意使用 pub 关键字println!(run toy);}
}
fn main() {use toy::run as toy_run; // 使用 use as 导入 toy 模块里的内容toy_run();
}例七 使用pub use命令在mod.rs合并打包其他模块的东西
src/toy/runner.rs
pub fn dog_run() { println!(dog is run !); }src/toy/fly.rs
pub fn fly_bird() { println!(bird is fly !); }src/toy/bear.rs
pub fn bear_eat() { println!(bear is eat fish !); }
pub fn bear_sleep() { println!(bear is go sleep !); }src/toy/mod.rs
mod runner; // 引入同级 runner.rs 文件
mod fly; // 引入同级 fly.rs 文件
mod bear; // 引入同级 bear.rs 文件
pub use runner::dog_run; // 声明导出 dog_run 函数
pub use fly::fly_bird as now_fly_brid; // 声明导出 fly_bird 函数并重命名为 now_fly_brid
pub use bear::*; // 声明导出 dog_run 函数src/main.rs
mod toy;
fn main() {toy::dog_run();toy::now_fly_brid();toy::bear_eat();toy::bear_sleep();
}输出
dog is run !
bird is fly !
bear is eat fish !
bear is go sleep !例七 使用pub mod导出内部包使用 crate 引用顶部内容
src/toy/cube/mod.rs
pub fn get_size() {println!(size is in main);crate::top_size(); // 必不可少的 crate 关键字
}src/toy/mod.rs
pub mod cube;src/main.rs
mod toy;
fn top_size() {println!(top size one !)
}
fn main() {toy::cube::get_size();
}输出
size is in main
top size one !