news 2026/3/11 3:05:12

CMake 基础

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CMake 基础

CMake 基础教程:从零开始掌握核心概念

CMake 是现代 C/C++ 项目最主流的构建系统工具,它不直接编译代码,而是根据你写的CMakeLists.txt文件生成平台原生的构建脚本(如 Makefile、Ninja、Visual Studio 项目等)。本篇聚焦基础,帮助你快速上手最常用的命令和写法。

1. CMake 的基本工作流程
  1. 编写CMakeLists.txt(项目配置文件)
  2. 在构建目录执行:
    cmake<源码路径># 配置阶段:生成构建系统(Makefile 等)cmake --build.# 构建阶段:真正编译

推荐始终使用源码外构建(out-of-source build):

mkdirbuildcdbuild cmake..# .. 表示源码目录cmake --build.
2. 最简 Hello World 项目

项目结构:

hello/ ├── CMakeLists.txt └── main.cpp

main.cpp

#include<iostream>intmain(){std::cout<<"Hello CMake!"<<std::endl;return0;}

CMakeLists.txt(基础必备三行)

cmake_minimum_required(VERSION 3.10) # 1. 指定 CMake 最低版本 project(HelloCMake # 2. 定义项目名称(可选指定语言) VERSION 1.0 DESCRIPTION "My first CMake project" LANGUAGES CXX) # 只启用 C++(默认启用 C 和 CXX) add_executable(hello main.cpp) # 3. 生成可执行目标 hello

构建运行:

mkdirbuild&&cdbuild cmake..cmake --build../hello# Linux/macOS# 或 hello.exe # Windows
3. 核心基础命令详解
命令作用常用写法
cmake_minimum_required(VERSION x.y)指定 CMake 最低版本,避免旧版本兼容问题cmake_minimum_required(VERSION 3.15)
project(name)定义项目名称、版本、描述、语言project(MyApp LANGUAGES CXX C)
add_executable(target sources...)创建可执行文件目标add_executable(app main.cpp util.cpp)
`add_library(target [STATICSHAREDMODULE] sources…)`
target_include_directories(target scope dirs...)为目标添加头文件搜索路径target_include_directories(app PRIVATE include)
target_link_libraries(target scope libs...)为目标链接库target_link_libraries(app PRIVATE pthread fmt)
set(CMAKE_CXX_STANDARD 17)全局设置 C++ 标准set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

scope(作用域)说明

  • PRIVATE:只影响当前目标(编译时使用)
  • INTERFACE:只影响依赖当前目标的其他目标
  • PUBLIC:两者都影响(最常用)
4. 指定 C++ 标准(非常重要)

推荐方式(现代 CMake):

# 方法1:全局设置(简单) set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON) # 方法2:目标级别(更灵活,推荐) target_compile_features(myapp PRIVATE cxx_std_17) # 支持 11/14/17/20/23
5. 多文件项目基础示例

项目结构:

myapp/ ├── CMakeLists.txt ├── main.cpp ├── include/ │ └── utils.h └── src/ └── utils.cpp

CMakeLists.txt

cmake_minimum_required(VERSION 3.15) project(MyApp LANGUAGES CXX) add_executable(myapp main.cpp src/utils.cpp ) target_include_directories(myapp PRIVATE include) # 添加 include 目录 target_compile_features(myapp PRIVATE cxx_std_17)
6. 基础变量一览
变量含义示例
${PROJECT_NAME}项目名称MyApp
${CMAKE_SOURCE_DIR}项目根源码目录/path/to/myapp
${CMAKE_BINARY_DIR}构建目录/path/to/myapp/build
${CMAKE_CURRENT_SOURCE_DIR}当前 CMakeLists.txt 所在目录用于子目录
${CMAKE_CXX_COMPILER}使用的 C++ 编译器g++ / clang++ / cl.exe
7. 常用构建类型
cmake..-DCMAKE_BUILD_TYPE=Debug# 调试版(带 -g)cmake..-DCMAKE_BUILD_TYPE=Release# 发布版(带 -O3)

在多配置生成器(如 Visual Studio)中,可在 IDE 中切换 Debug/Release。

8. 基础小结 checklist

一个合格的基础CMakeLists.txt通常包含:

cmake_minimum_required(VERSION 3.15) # 现代版本起点 project(MyProject VERSION 1.0 LANGUAGES CXX) add_executable(${PROJECT_NAME} # 使用项目名作为目标名 main.cpp src/file1.cpp src/file2.cpp) target_include_directories(${PROJECT_NAME} PRIVATE include) target_compile_features(${PROJECT_NAME} PRIVATE cxx_std_17)

掌握以上内容,你已经能管理 90% 的小型到中型 C++ 项目了!

后续可以继续学习:

  • 子目录管理(add_subdirectory()
  • 查找外部库(find_package()
  • 安装规则(install()
  • 测试(add_test()+ CTest)

如果你想看更具体的例子(如添加第三方库、静态/动态库分离、多目录结构等),随时告诉我,我继续深入讲解!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/4 7:02:30

CMake 构建实例

CMake 构建实例&#xff1a;从简单到复杂实战项目 下面通过4个逐步升级的实际项目实例&#xff0c;展示 CMake 的完整构建流程、目录结构和 CMakeLists.txt 编写。所有实例都遵循现代 CMake 最佳实践&#xff08;CMake 3.15&#xff0c;target-centric 写法&#xff0c;源码外…

作者头像 李华
网站建设 2026/3/8 7:12:23

5分钟掌握Qwen-Image-Edit-Rapid-AIO:AI图像编辑的终极解决方案

5分钟掌握Qwen-Image-Edit-Rapid-AIO&#xff1a;AI图像编辑的终极解决方案 【免费下载链接】Qwen-Image-Edit-Rapid-AIO 项目地址: https://ai.gitcode.com/hf_mirrors/Phr00t/Qwen-Image-Edit-Rapid-AIO 还在为复杂的AI图像编辑工具而烦恼吗&#xff1f;Qwen-Image-E…

作者头像 李华
网站建设 2026/3/10 0:55:26

PyMongo深度探索:超越基础CRUD的高性能数据操作指南

PyMongo深度探索&#xff1a;超越基础CRUD的高性能数据操作指南 引言&#xff1a;为什么PyMongo不仅仅是MongoDB的Python包装器 MongoDB作为现代文档数据库的代表&#xff0c;已经成为许多数据密集型应用的首选存储方案。而在Python生态中&#xff0c;PyMongo作为官方驱动程序…

作者头像 李华
网站建设 2026/3/9 13:42:56

React右键菜单终极指南:3分钟实现专业级上下文菜单

React右键菜单终极指南&#xff1a;3分钟实现专业级上下文菜单 【免费下载链接】react-contextmenu Project is no longer maintained 项目地址: https://gitcode.com/gh_mirrors/re/react-contextmenu 在React应用开发中&#xff0c;右键菜单功能是提升用户体验的重要交…

作者头像 李华
网站建设 2026/3/5 10:38:54

CLIPSeg图像分割:用文字和图片精准定位目标的终极工具

CLIPSeg图像分割&#xff1a;用文字和图片精准定位目标的终极工具 【免费下载链接】sd-webui-deforum Deforum extension for AUTOMATIC1111s Stable Diffusion webui 项目地址: https://gitcode.com/gh_mirrors/sd/sd-webui-deforum 想要用简单的文字描述或参考图片就能…

作者头像 李华
网站建设 2026/3/7 6:37:14

React-Three-Fiber 终极指南:快速构建惊艳3D应用的5个步骤

React-Three-Fiber 终极指南&#xff1a;快速构建惊艳3D应用的5个步骤 【免费下载链接】react-three-fiber 项目地址: https://gitcode.com/gh_mirrors/rea/react-three-fiber React-Three-Fiber&#xff08;简称R3F&#xff09;是Three.js的React渲染器&#xff0c;让…

作者头像 李华