news 2026/4/16 16:18:15

CMake几个命令顺序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CMake几个命令顺序

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

      • 关键顺序规则:
      • 示例说明
      • 顺序解释:
      • 错误顺序的后果:

在 CMake 中,target_include_directoriestarget_link_directoriesadd_librarytarget_link_libraries的使用存在明确的先后顺序,核心原则是:先创建目标(add_library),再配置目标的属性(target_include_directoriestarget_link_directories),最后链接依赖(target_link_libraries。同时,被链接的目标(如库)必须在链接命令之前创建。

关键顺序规则:

  1. add_library必须最先执行:因为target_*系列命令(包括target_include_directoriestarget_link_directoriestarget_link_libraries)的操作对象是“目标”(如库或可执行文件),必须先通过add_library(或add_executable用于可执行文件)创建目标,否则 CMake 会报错“目标不存在”。
  2. target_include_directoriestarget_link_directories需在目标创建后、链接前执行:这两个命令是给目标设置“编译时头文件路径”和“链接时库路径”,需要在目标被链接(target_link_libraries)前完成配置,否则可能导致编译或链接时找不到路径。
  3. target_link_libraries需在被链接的目标创建后执行:如果要链接的是通过add_library创建的自定义库,必须先通过add_library生成该库目标,再用target_link_libraries链接,否则会找不到依赖库。

示例说明

假设一个工程结构如下(多模块项目,包含一个自定义库mylib和一个依赖它的可执行文件myapp):

project/ ├── CMakeLists.txt ├── include/ # 公共头文件目录 │ └── mylib.h ├── src/ │ ├── mylib.cpp # 库的源文件 │ └── main.cpp # 可执行文件的源文件

对应的CMakeLists.txt正确顺序如下:

# 1. 最低版本要求(必须在 project 前) cmake_minimum_required(VERSION 3.10) # 2. 定义项目 project(MyProject LANGUAGES CXX) # -------------------------- # 步骤1:创建库目标(add_library 必须先执行) # -------------------------- add_library(mylib STATIC src/mylib.cpp # 库的源文件 ) # -------------------------- # 步骤2:配置库的头文件路径(target_include_directories 在目标创建后) # -------------------------- # 为 mylib 设置头文件目录,PUBLIC 表示依赖 mylib 的目标(如 myapp)会自动继承该路径 target_include_directories(mylib PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include # 公共头文件目录 ) # -------------------------- # 步骤3:创建可执行目标(依赖 mylib,需在链接前创建) # -------------------------- add_executable(myapp src/main.cpp # 可执行文件的源文件 ) # -------------------------- # 步骤4:(可选)配置可执行文件的链接路径(如果有额外库路径) # -------------------------- # 假设 myapp 还需要链接第三方库,其路径在 ./third_party/lib target_link_directories(myapp PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/third_party/lib ) # -------------------------- # 步骤5:链接依赖库(target_link_libraries 在被链接目标创建后) # -------------------------- # 让 myapp 链接自定义库 mylib(mylib 已通过 add_library 创建) # 同时链接第三方库(如 pthread 或其他) target_link_libraries(myapp PRIVATE mylib # 自定义库(必须先通过 add_library 创建) pthread # 系统库(无需提前创建) )

顺序解释:

  1. add_library(mylib ...)先执行:创建库目标mylib,后续的target_include_directories(mylib ...)才能操作这个目标。
  2. target_include_directories(mylib ...)紧随其后:为mylib设置头文件路径,由于用了PUBLIC,后续依赖mylibmyapp会自动继承这个路径(无需再给myapp重复设置include目录)。
  3. add_executable(myapp ...)创建可执行目标myapp是最终要生成的程序,必须先创建才能对其配置链接路径和依赖。
  4. target_link_directories(myapp ...)配置链接路径:如果myapp需要链接额外的第三方库,需在链接前指定其路径(否则链接器可能找不到库文件)。
  5. target_link_libraries(myapp ...)最后链接:此时mylib已存在,myapp的链接路径也已配置,链接操作才能正常执行。

错误顺序的后果:

  • 如果在add_library(mylib)之前调用target_include_directories(mylib ...),CMake 会报错:Cannot specify include directories for target "mylib" which is not built by this project(目标不存在)。
  • 如果在add_library(mylib)之前调用target_link_libraries(myapp mylib),CMake 会报错:Target "myapp" links to target "mylib" which is not built by this project(被链接的目标不存在)。

因此,严格遵循“先创建目标 → 再配置属性 → 最后链接依赖”的顺序是保证 CMake 脚本正确执行的基础。。

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

CMake链接配置为何不用链接路径

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录前言核心原因:CMake的“目标(target)”是元数据容器1. add_library(mylib src/lib.cpp) 做了什么?2. target_link_lib…

作者头像 李华
网站建设 2026/4/16 10:46:53

Coinstore B.KU 数字金融与 RWA 主题活动圆满举行

2025 年 1 月 8 日,由 Coinstore B.KU 主办的「数字金融与 RWA(Real World Assets,现实世界资产)主题活动」顺利举行。来自数字金融、区块链技术、传统产业及国际组织的多位嘉宾齐聚现场,围绕 RWA 发展趋势、数字金融结…

作者头像 李华
网站建设 2026/4/14 18:41:33

快速理解USB over Network在Win平台的工作机制

深入Windows平台的USB over Network:从驱动到网络的透明外设共享你有没有遇到过这样的场景:公司唯一的硬件加密狗插在办公室某台电脑上,而你正在家里远程办公;或者实验室里那台精密仪器只能通过本地USB连接,但数据分析…

作者头像 李华
网站建设 2026/4/16 10:43:42

数字孪生实现工厂三维可视化:图解说明

数字孪生如何让工厂“活”起来?一文讲透三维可视化的底层逻辑 你有没有遇到过这样的场景:车间里设备报警了,但调度员盯着一堆跳动的数字和二维流程图,根本找不到问题出在哪台机器;新员工培训要花几周时间才能熟悉产线…

作者头像 李华