news 2026/2/6 5:06:13

CMake 常用预设命令说明

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CMake 常用预设命令说明

CMake 常用预设命令说明

在使用 CMake 构建 C/C++ 项目时,我们通常需要在CMakeLists.txt文件中定义一些基础设置,以确保项目能够在不同平台和编译器下正确构建。本文将介绍一些最常用的预设命令,包括指定 CMake 版本、设置编译模式、显示构建信息以及指定 C++ 标准等。


一、指定 CMake 的最小版本

CMakeLists.txt的开头,推荐使用以下命令指定所需的最低 CMake 版本:

cmake_minimum_required(VERSION 3.16)

该命令的作用是告诉 CMake,当前项目至少需要 3.16 版本才能正确运行。
如果使用了某些新特性(例如target_link_libraries的现代用法),而版本太低,就会在配置阶段报错。


二、定义项目名称及语言

定义项目名称和使用的编程语言:

project(MyProject LANGUAGES CXX)
  • MyProject是项目名称;
  • LANGUAGES可以指定C,CXX,CUDA,Fortran等;
  • 声明了语言后,CMake 会自动为该语言加载相应的规则和工具链。

三、设置编译模式(构建类型)

CMake 通常支持以下几种构建类型:

  • Debug—— 含有调试信息,不进行优化;
  • Release—— 开启优化,去除调试信息;
  • RelWithDebInfo—— 优化同时保留部分调试信息;
  • MinSizeRel—— 优化为最小体积。

可以通过以下方式设置默认的构建类型:

set(CMAKE_BUILD_TYPE Release)

💡 注意:

  • 在多配置生成器(如 Visual Studio、Xcode)中,CMAKE_BUILD_TYPE无效,需要在生成时选择配置。
  • 对于单配置生成器(如 Makefile、Ninja),上述变量才生效。

四、控制编译输出与信息显示

在开发调试中,可能需要输出更多的构建信息。CMake 提供了以下命令来控制消息显示:

message(STATUS "当前构建类型: ${CMAKE_BUILD_TYPE}") message(WARNING "这是一个警告信息") message(FATAL_ERROR "出现致命错误,终止配置")

常用的消息等级包括:

  • STATUS—— 普通状态信息;
  • WARNING—— 发出警告,不中断;
  • FATAL_ERROR—— 输出错误并停止执行。

此外,可通过命令行参数控制详细程度,例如:

cmake -DCMAKE_VERBOSE_MAKEFILE=ON..

这会让构建系统在编译时显示具体的命令行。


五、指定 C++ 标准版本

在现代 CMake 中,推荐使用以下语法来指定所需的 C++ 标准版本:

set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON) set(CMAKE_CXX_EXTENSIONS OFF)

说明:

  • CMAKE_CXX_STANDARD指定 C++ 标准(如 11、14、17、20、23 等);
  • CMAKE_CXX_STANDARD_REQUIRED表示版本必须满足或高于指定标准;
  • CMAKE_CXX_EXTENSIONS OFF关闭编译器特有的扩展(如 GNU 扩展)。

六、典型的CMakeLists.txt示例

以下是一个简单示例,展示了本文中提到的关键命令:

cmake_minimum_required(VERSION 3.20) project(MyProject LANGUAGES CXX) # 设置构建类型 set(CMAKE_BUILD_TYPE Debug) # 指定 C++17 标准 set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON) set(CMAKE_CXX_EXTENSIONS OFF) # 输出构建信息 message(STATUS "构建类型:${CMAKE_BUILD_TYPE}") message(STATUS "C++标准版本:${CMAKE_CXX_STANDARD}") # 添加源文件并生成可执行文件 add_executable(MyProject main.cpp)

运行命令构建项目:

cmake -B build -S.cmake --build build

七、总结

功能常用命令示例
指定 CMake 版本cmake_minimum_requiredcmake_minimum_required(VERSION 3.20)
定义项目projectproject(MyApp LANGUAGES CXX)
设置构建模式set(CMAKE_BUILD_TYPE ...)set(CMAKE_BUILD_TYPE Release)
输出信息message(STATUS ...)message(STATUS "构建类型:${CMAKE_BUILD_TYPE}")
C++ 标准版本set(CMAKE_CXX_STANDARD ...)set(CMAKE_CXX_STANDARD 17)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/3 17:32:27

博途HSP文件安装失败报错原因

S7-1500轴工艺对象105报文安装(硬件目录的支持包 HSP) https://rxxw-control.blog.csdn.net/article/details/140102501?spm1011.2415.3001.5331https://rxxw-control.blog.csdn.net/article/details/140102501?spm1011.2415.3001.5331 1、错误界面 如果是上面的结果&#…

作者头像 李华
网站建设 2026/2/3 15:43:19

SpringBoot+Vue 社区老人健康信息管理系统管理平台源码【适合毕设/课设/学习】Java+MySQL

摘要 随着社会老龄化的加剧,社区老年人的健康管理问题日益受到关注。传统的健康信息管理方式依赖纸质记录或分散的系统,存在效率低、数据易丢失、信息共享困难等问题。为了解决这些问题,设计并实现一个高效、便捷的社区老人健康信息管理系统具…

作者头像 李华
网站建设 2026/1/30 5:58:12

三极管饱和与截止状态:图解说明易理解

三极管开关怎么用才不发热?深入解析饱和与截止的实战要点你有没有遇到过这种情况:用三极管控制一个继电器,明明代码写对了,但三极管却烫得像要冒烟?或者发现负载明明该断电,却还微微亮着?问题很…

作者头像 李华
网站建设 2026/1/31 10:09:46

合作伙伴计划推出:招募代理商扩大市场覆盖

合作伙伴计划推出:招募代理商扩大市场覆盖 在企业智能化转型的浪潮中,一个现实问题始终困扰着组织决策者:如何让大语言模型真正“懂”自己的业务?通用AI助手或许能流畅回答百科问题,但在面对内部制度、客户合同或技术文…

作者头像 李华
网站建设 2026/1/30 23:13:49

快速引流策略曝光:用Anything-LLM生成高质量SEO技术文章

快速引流策略曝光:用Anything-LLM生成高质量SEO技术文章 在搜索引擎竞争日益激烈的今天,技术类内容的创作早已不再是“写得越多越好”,而是“谁更专业、谁更可信、谁更能解决实际问题”。然而,许多团队仍困于一个尴尬境地&#x…

作者头像 李华