Rust 模块系统:控制作用域与私有性

文章目录

Rust 模块系统:控制作用域与私有性

模块(mod)是 Rust 组织代码的核心机制,用于封装代码、管理作用域和实现私有性控制。核心概念包括:模块声明路径(paths)pub 公开性use 快捷引用


一、模块声明规则
  1. 起点:Crate 根文件

    • 编译器从 crate 根文件开始编译:
      • 库 crate:src/lib.rs
      • 二进制 crate:src/main.rs
  2. 声明模块的三种方式

    在 crate 根文件声明 mod garden; 时,编译器按顺序查找:

    • 内联代码:mod garden { /* 代码 */ }
    • 文件 src/garden.rs
    • 文件 src/garden/mod.rs
  3. 子模块声明

    在非根文件(如 src/garden.rs)中声明子模块 mod vegetables; 时,查找位置:

    • 内联代码:mod vegetables { /* 代码 */ }
    • 文件 src/garden/vegetables.rs
    • 文件 src/garden/vegetables/mod.rs

文件结构示例

复制代码
backyard
├── Cargo.toml
└── src
    ├── garden
    │   └── vegetables.rs  // 子模块代码
    ├── garden.rs         // 模块声明
    └── main.rs           // crate 根

二、路径(Paths)访问规则
  • 通过路径访问模块内项(如结构体、函数):

    rust 复制代码
    crate::garden::vegetables::Asparagus // 绝对路径
  • 路径类型:

    • 绝对路径 :从 crate 根开始
    • 相对路径 :从 self(当前模块)或 super(父模块)开始

三、私有性控制(pub 关键字)
  1. 默认私有

    • 模块内项(函数/结构体等)默认 对父模块私有
    • 子模块可访问父模块,但父模块不能访问子模块私有项。
  2. 公开作用域

    rust 复制代码
    pub mod garden {          // 公开模块
        pub mod vegetables {   // 公开子模块
            pub struct Asparagus; // 公开项
        }
    }
    • pub mod:使模块可从外部访问
    • pub 修饰项:使模块内的特定项公开

四、use 关键字:简化路径
  • 创建快捷方式避免重复长路径:

    rust 复制代码
    use crate::garden::vegetables::Asparagus;
    fn main() {
        let plant = Asparagus; // 直接使用短名
    }
  • 常用组合:

    rust 复制代码
    use crate::garden::vegetables; // 引入模块,通过 vegetables::Asparagus 访问
    use crate::garden::vegetables::Asparagus as Veg; // 重命名

五、模块树结构示例

代码示例(餐厅管理系统):

rust 复制代码
// src/lib.rs
mod front_of_house {     // 模块
    pub mod hosting {     // 子模块(公开)
        pub fn add_to_waitlist() {} // 公开函数
    }
}

模块树结构

复制代码
crate
└── front_of_house
    └── hosting
        └── add_to_waitlist

关键总结
机制 作用 示例
mod 声明模块 mod garden;
pub 公开模块或项 pub fn seat_at_table()
crate:: 绝对路径起点 crate::garden::Asparagus
use 创建路径别名 use crate::garden;
文件系统映射 模块与文件自动关联 garden.rsmod garden

模块系统通过文件路径映射和层级访问控制,实现了代码的高效组织与封装,是 Rust 安全性的重要基石。

相关推荐
sinat_602035362 分钟前
模块与包的导入
运维·服务器·开发语言·python
计算机学姐2 分钟前
基于Python的旅游数据分析可视化系统【2026最新】
vue.js·后端·python·数据分析·django·flask·旅游
恋雨QAQ3 分钟前
python函数和面向对象
开发语言·python
天雪浪子21 分钟前
Python入门教程之逻辑运算符
开发语言·python
落羽的落羽35 分钟前
【C++】特别的程序错误处理方式——异常机制
开发语言·c++
该用户已不存在40 分钟前
你没有听说过的7个Windows开发必备工具
前端·windows·后端
通达的K1 小时前
Java实战项目演示代码及流的使用
java·开发语言·windows
David爱编程1 小时前
深入 Java synchronized 底层:字节码解析与 MonitorEnter 原理全揭秘
java·后端
KimLiu1 小时前
LCODER之Python:使用Django搭建服务端
后端·python·django