在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
$ rustc --version 将代码存在到不同的文件 main.rs mod aa; fn main() { println!("------------------------------------"); aa::aa1(); } mod aa表示引入aa模块,在rust中一个文件名就代表一个模块,创建aa.rs文件 aa.rs pub fn aa1(){ println!("---aa-----"); } $ cargo run Compiling crate_path v0.1.0 (/opt/wks/rust_study/crate_path) Finished dev [unoptimized + debuginfo] target(s) in 0.20s Running `target/debug/crate_path` ------------------------------------ ---aa-----
将代码存到不到的目录
src下第一层目录文件结构 aa aa.rs main.rs aa目录下有文件 bb.rs cc.rs rust中mod模块与文件名一一对应,存在一个mod aa,就必须得有一个叫aa.rs的文件存在; 但文件中不能再放文件,目录才可以放文件,于是rust就创建一个同名的目录,也叫aa,目录aa下再放其他文件
main.rs mod aa; fn main() { println!("------------------------------------------------"); aa::bb::bb1(); aa::cc::cc1(); }
aa.rs pub mod bb;
pub mod cc;
aa/bb.rs pub fn bb1(){ println!("-----------bb1-----------"); }
aa/cc.rs pub fn cc1(){ println!("--------------cc1------------"); }
上面是两个可运行的例子,下面是完整的体系式的概念
Packages and Crates A package is one or more crates that provide a set of functionality. A package contains a Cargo.toml file that describes how to build those crates. A crate is a binary or library. src/main.rs is the crate root of a binary crate with the same name as the package. Likewise, Cargo knows that if the package directory contains src/lib.rs, the package contains a library crate with the same name as the package, and src/lib.rs is its crate root. Cargo passes the crate root files to $ cargo new my-project Created binary (application) `my-project` package $ ls my-project Cargo.toml src $ ls my-project/src main.rs
Here, we have a package that only contains src/main.rs, meaning it only contains a binary crate named
Defining Modules to Control Scope and Privacy the . Create a new library named mod front_of_house {
mod hosting {
fn add_to_waitlist() {}
fn seat_at_table() {}
}
mod serving {
fn take_order() {}
fn serve_order() {}
fn take_payment() {}
}
}
fn main() {}
By using modules, we can group related definitions together and name why they’re related. Programmers using this code would have an easier time finding the definitions they wanted to use because they could navigate the code based on the groups rather than having to read through all the definitions. Programmers adding new functionality to this code would know where to place the code to keep the program organized. Earlier, we mentioned that src/main.rs and src/lib.rs are called crate roots. The reason for their name is that the contents of either of these two files form a module named crate
└── front_of_house
├── hosting
│ ├── add_to_waitlist
│ └── seat_at_table
└── serving
├── take_order
├── serve_order
└── take_payment
如果你有很多文件,要在A文件中引用B的模型,就可以从根模型开始引用, 比如 crate::serving::take_order 从 crate:: 你可以路径到任一个定义的 mod, 只要它们有 pub 权限
Paths for Referring to an Item in the Module Tree A path can take two forms:
An absolute path starts from a crate root by using a crate name or a literal crate.
A relative path starts from the current module and uses self, super, or an identifier in the current module.
Both absolute and relative paths are followed by one or more identifiers separated by double colons (::).
Bringing Paths into Scope with the use Keyword 创建新项目 aa.rs mod bb { pub mod bb1{ pub fn bb1_1(){ println!("aa --> bb --> bb1 --> bb1_1"); } pub fn bb1_2(){ println!("-----self ----------------"); self::bb1_1(); } } pub fn bb2(){ println!("aa --> bb --> bb2"); } } //相当于在本crate中提供一个pub方法,供外部调用 use self::bb::bb1::bb1_1 as b1; pub fn aa1(){ b1(); } //让pub bb2在其父mod bb私有的提前下,可供外部程序调用 //bb2本身必须pub pub use self::bb::bb2; //对外提供一个pub模块 pub mod cc { //crate是绝对路径,root crate是main.rs use crate::aa::bb::bb1::bb1_2 as b2; pub fn cc1(){ b2(); } pub mod cc2{ pub fn cc2_1(){ println!("aa --> cc --> cc2 --> cc2_1"); } } } main.rs mod aa; use aa::cc::cc2; fn main(){ println!("-----------------------------------"); aa::aa1(); aa::cc::cc1(); aa::bb2(); cc2::cc2_1(); } 输出 $ cargo run Compiling test_lib v0.1.0 (/opt/wks/rust_study/test_lib) Finished dev [unoptimized + debuginfo] target(s) in 0.21s Running `target/debug/test_lib` ----------------------------------- aa --> bb --> bb1 --> bb1_1 -----self ---------------- aa --> bb --> bb1 --> bb1_1 aa --> bb --> bb2 aa --> cc --> cc2 --> cc2_1
====================================================================================== 上面的方式是可以运行的,但每个目录还要建立一个同名的rs文件,看上去不怎么好看。下面介绍另外一种方式 将同名的rs文件放到同名的目录下,统一重命名为mod.rs
其他的没有变化,移动位置,重命名为mod.rs,然后就可以了
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论