0

0

C++构建系统升级:C++23 Modules标准化构建流程【告别Makefile混乱】

冰火之心

冰火之心

发布时间:2026-01-28 10:33:00

|

476人浏览过

|

来源于php中文网

原创

根本原因是模块接口单元(.ixx)未被CMake识别为源文件,导致Clang未生成.pcm文件;需显式启用模块支持、指定缓存路径、正确声明库类型并避免与GCC标准库模块误用。

c++构建系统升级:c++23 modules标准化构建流程【告别makefile混乱】

为什么 import 在 Clang 17 + CMake 3.28 下仍报错 “module file not found”

根本原因不是语法写错,而是模块接口单元(.ixx)没被 CMake 正确识别为模块源,导致编译器根本没生成 .pcm 文件。Clang 默认不自动扫描 .ixx,必须显式启用模块支持并指定输出路径。

  • 确保 CMakeLists.txt 中启用 set(CMAKE_CXX_STANDARD 23)set(CMAKE_CXX_STANDARD_REQUIRED ON)
  • 对每个模块添加 target_compile_options(${tgt} PRIVATE -fmodules -fimplicit-modules -fimplicit-module-maps)(Clang)或 /experimental:module /module:interface(MSVC)
  • 模块源文件必须用 source_group("Modules" FILES math.ixx) 显式加入构建,否则 CMake 会跳过它
  • Clang 要求 .pcm 输出目录可写,建议统一设为 ${CMAKE_BINARY_DIR}/modules 并用 -fmodules-cache-path=... 指定

CMake 3.28 的 add_library(... MODULE) 和传统静态库冲突吗

会冲突,但不是命名冲突,而是链接语义冲突:MODULE 在 CMake 里特指“动态加载模块”(如插件),和 C++23 Modules 完全无关。误用会导致链接失败或运行时 dlopen 错误。

  • 所有 C++23 模块都应使用 add_library(math INTERFACE)add_library(math STATIC),再通过 target_sources(math PRIVATE math.ixx) 注入模块文件
  • INTERFACE 库适合纯接口模块(无实现),STATIC 适合含 module implementation partition 的场景
  • 必须调用 target_compile_features(math PUBLIC cxx_modules),否则 CMake 不会向编译器传递模块相关 flag
  • 跨模块依赖需用 target_link_libraries(consumer PRIVATE math),CMake 会自动处理 .pcm 依赖顺序

如何让 GCC 13 正确解析 import std.core; 而不报 “no module map for ‘std.core’”

GCC 13 对标准库模块支持极弱,std.core 等模块名是 Clang/MSVC 的非标准扩展,GCC 官方尚未实现任何 std.* 模块。强行启用只会触发未定义行为。

Figma
Figma

Figma 是一款基于云端的 UI 设计工具,可以在线进行产品原型、设计、评审、交付等工作。

下载
  • 放弃 import std.core;,改用传统头文件包含(#include )或 GCC 实验性模块:先运行 g++-13 --preprocess -fmodules-ts stdc++.h 生成 stdc++.gcm,再 import "stdc++.gcm";
  • 若坚持用标准库模块,必须切换到 Clang 17+ 或 MSVC 19.35+,且项目中禁用 GCC 工具
  • 检查 __cpp_modules 宏值:GCC 13 返回 201907L(仅支持 TS),Clang 17 返回 202207L(支持标准化语法)
  • 模块映射文件(module.modulemap)在 GCC 下无效,不要尝试手写

从 Makefile 迁移后,为什么 make clean 不再删除 .pcm 文件

因为 CMake 默认不把 .pcm 当作可清理产物——它被归类为“编译器缓存”,而非构建目标。CMake 的 clean 只清理 add_executable/add_library 生成的文件。

立即学习C++免费学习笔记(深入)”;

  • CMakeLists.txt 末尾添加:
    add_custom_target(clean_modules
      COMMAND ${CMAKE_COMMAND} -E remove_directory ${CMAKE_BINARY_DIR}/modules
      COMMENT "Cleaning module cache"
    )
  • 将清理任务绑定到全局 clean:
    add_dependencies(clean clean_modules)
  • 若使用 Ninja,还需在 configure_file() 中注入 build clean_modules: phonybuild.ninja
  • 注意:频繁删 .pcm 会显著拖慢增量构建,建议只在 CI 或调试模块依赖时启用
模块构建真正的难点不在语法,而在编译器、CMake 版本、标准库实现三者间的隐式耦合——一个版本不匹配,import 就变成编译器静默忽略的注释。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1100

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

189

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1500

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

18

2026.01.19

go中interface用法
go中interface用法

本专题整合了go语言中int相关内容,阅读专题下面的文章了解更多详细内容。

76

2025.09.10

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

60

2025.11.17

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

21

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.2万人学习

Pandas 教程
Pandas 教程

共15课时 | 1.0万人学习

ASP 教程
ASP 教程

共34课时 | 4.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号