C++模块是C++20引入的替代头文件的新型编译单元,通过接口单元(export module)和实现单元(module)分离声明与定义,以import取代#include,实现宏隔离、依赖显式化和真正封装。
C++模块(Modules)是C++20正式引入的核心特性,本质是一种**替代或补充传统头文件的新型编译单元**。它不是语法糖,也不是简单的#include包装,而是从编译模型层面重构了代码组织与依赖管理方式:模块内容被独立编译为二进制接口描述(如.ifc文件),导入时直接加载解析结果,跳过预处理和重复文本展开。
一个模块通常由两部分组成——接口单元(声明“能用什么”)和实现单元(定义“怎么实现”):
.ixx 或 .cppm)以 export module 模块名; 开头,用 export 显式标出对外可见的函数、类、命名空间等。例如:export module math;export int add(int a, int b) { return a + b; }
.cpp 文件)以 module 模块名; 声明归属,不加 export,内部可自由使用标准库、头文件或私有辅助逻辑。例如:module math;#include int multiply(int a, int b) { std::cout (该函数未导出,仅模块内可用)
在普通源文件(如 main.cpp)中,用 import 加载模块,不再需要 #include 对应的头文件:
import std; —— 导入整个标准化的标准库模块(VS 2025 17.5+ 已完全支持)import math; —— 导入自定义模块,之后可直接调用 add(2, 3),无需声明前置import :private; 或 import 模块名:分区; —— 支持模块内部分区,实现更细粒度封装注意:import 必须出现在所有 #include 之前(除极少数兼容场景),且不能出现在函数体内。
模块带来的不只是编译提速(大型项目实测常达 2–5 倍),关键在于它解决了长期困扰 C++ 工程的底层顽疾:
#define、#ifdef 完全不泄漏到导入它的翻译单元,杜绝“头文件改一个宏,全项目重编译”module :private; 还能进一步隐藏实现细节新项目可直接用模块起步;老项目不必强求全量替换,推荐分三步走:
import
等标准库模块替代 #include (零风险,纯收益)import 或通过编译器选项将 .h 编译为模块(如 MSVC 的 /headerUnit)基本上就这些。模块不是必须立刻全面铺开的银弹,但它是 C++ 向现代化工程语言迈出最扎实的一步。