0

0

c++怎么配置cmake工程_c++多文件编译管理【指南】

冰火之心

冰火之心

发布时间:2026-03-15 20:25:31

|

585人浏览过

|

来源于php中文网

原创

应设 cmake_minimum_required(VERSION 3.10 起),避免旧版语法被新 CMake 拒绝;add_executable 必须显式列出所有 .cpp 文件,GLOB 需手动刷新缓存;头文件路径应用 target_include_directories 绑定 target;修改 CMakeLists.txt 后必须重新运行 cmake .. 再构建。

c++怎么配置cmake工程_c++多文件编译管理【指南】

cmake_minimum_required 版本设太低会报错

很多新手直接抄网上旧教程,写 cmake_minimum_required(VERSION 2.8),结果在现代 CMake(比如 3.20+)下跑 add_compile_optionstarget_compile_features 时突然失败——不是语法错,而是 CMake 自己拒绝解析。CMake 在较新版本里对旧语法做了静默弃用或严格校验。

  • 当前稳妥起点是 cmake_minimum_required(VERSION 3.10),覆盖 Ubuntu 20.04+/macOS Homebrew 默认版本
  • 若用 target_compile_features(比如要 C++17 std::optional),至少得 VERSION 3.12
  • 别硬套项目里别人写的版本号;运行 cmake --version 看你本地实际版本,往上取整到最近的 LTS 小版本(如 3.16、3.22)更安全

add_executable 里漏掉 .cpp 文件就链接失败

常见现象:编译通过,但链接时报 undefined reference to `xxx`,尤其函数定义在 utils.cpp 里,而 CMakeLists.txt 只写了 add_executable(main main.cpp)。CMake 不自动扫描目录,它只认你显式列出来的源文件。

  • 必须把所有参与构建的 .cpp 都列进 add_executableadd_library,例如:add_executable(myapp main.cpp utils.cpp logger.cpp)
  • 想避免手写一长串?用 file(GLOB SOURCES "*.cpp"),但注意:GLOB 不会自动触发重新配置,改了文件名或增删文件后得手动删 build/ 下的缓存再 cmake ..
  • 不推荐 GLOB_RECURSE 深层扫描——容易误包测试文件或第三方代码,显式列举反而更可控

include_directories 和 target_include_directories 的区别

老写法 include_directories(./include) 看似能编译过,但会导致所有 target 共享头路径,污染依赖关系。一旦工程变大,A 库用了 B 库的头但没声明依赖,编译可能侥幸成功,换机器或清理构建就崩。

B12
B12

B12是一个由AI驱动的一体化网站建设平台

下载
  • 正确做法是绑定到具体 target:target_include_directories(myapp PRIVATE ./include)
  • PRIVATE 表示只本 target 编译时用;PUBLIC 表示本 target 用 + 依赖它的其他 target 也能用(适合库的头暴露);INTERFACE 表示只给依赖者用(纯头文件库)
  • 路径尽量用相对 CMAKE_CURRENT_SOURCE_DIR,别写绝对路径;./include../include 更易维护

生成 Makefile 后修改 CMakeLists.txt 必须重新 cmake

很多人改完 CMakeLists.txt 直接 make,发现新加的 target_compile_options 没生效,或者 find_package 找不到库——因为 make 只执行构建,不重读 CMake 配置。

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

  • 每次改 CMakeLists.txt 后,进 build/ 目录运行 cmake ..(或 cmake -G "Unix Makefiles" ..),再 make
  • 如果只是改了源码,不用重 cmake;但只要动了构建逻辑(target 名、include 路径、link 库、编译选项),就得重来
  • 用 Ninja 生成器(cmake -G Ninja ..)比 Makefile 快,且 Ninja 本身会检查 CMakeCache.txt 是否过期,但依然不能跳过 cmake .. 这步
CMake 不是“写一次就完事”的工具,它的配置和构建是两个阶段,中间靠缓存文件粘合;漏掉重配置这一步,后面所有编译行为都不可信。

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
go中interface用法
go中interface用法

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

78

2025.09.10

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6556

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3348

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1699

2025.12.25

macOS怎么切换用户账户
macOS怎么切换用户账户

在 macOS 系统中,可通过多种方式切换用户账户。如点击苹果图标选择 “系统偏好设置”,打开 “用户与群组” 进行切换;或启用快速用户切换功能,通过菜单栏或控制中心的账户名称切换;还能使用快捷键 “Control+Command+Q” 锁定屏幕后切换。

359

2025.05.09

常见的linux系统有哪些
常见的linux系统有哪些

linux系统有Ubuntu、Fedora、CentOS、Debian、openSUSE、Arch Linux、Gentoo、Slackware、Linux Mint、Kali Linux。更多关于linux系统的文章详情请阅读本专题下面的文章。php中文网欢迎大家前来学习。

858

2023.10.27

ubunt上安装和配置vnc
ubunt上安装和配置vnc

安装方法:安装VNC服务器、启动VNC服务器、设置VNC密码等等。想了解更多ubuntu的相关内容,可以阅读本专题下面的文章。

431

2023.12.28

ubuntu启动黑屏解决方法
ubuntu启动黑屏解决方法

ubuntu启动黑屏解决方法:检查是否是电源问题、检查内存是否接触不良、检查显卡问题等。想了解更多ubuntu的相关内容,可以阅读本专题下面的文章。

675

2023.12.28

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

69

2026.03.13

热门下载

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

精品课程

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

共94课时 | 11.4万人学习

C 教程
C 教程

共75课时 | 5.5万人学习

C++教程
C++教程

共115课时 | 22.1万人学习

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

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