当前位置: 首页 > news >正文

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 脚本正确执行的基础。。

http://www.jsqmd.com/news/222566/

相关文章:

  • 数字医疗在公共卫生事件中的重要作用
  • 佳能主流打印机型号万能清零工具:原理与使用详解【P07/5B00解决方案指南】
  • CMake工程是否引用三方库的头文件
  • vTaskDelay在工业控制中的延时机制深度剖析
  • 边沿触发D触发器电路图通俗解释:建立与保持时间分析
  • CMake成果打包
  • 用于体素医学图像分割的跨视图差异-依赖网络/文献速递-基于人工智能的医学影像技术
  • 高校电工实验中Multisim元器件图标的教学实践指南
  • 深度剖析Packet Tracer汉化文件结构:技术细节公开
  • I2C与UART对比入门:初学者的核心区别分析
  • 或非门在工业控制中的逻辑设计:深度剖析应用原理
  • 开源模型落地实践|Qwen2.5-7B-Instruct结构化生成全解析
  • 模拟I2C协议在远程IO模块中的操作指南
  • 拒绝“天价”硬件吃灰:企业AI转型如何避开“只烧钱不落地”的深坑?
  • 基于SPICE的二极管IV特性曲线全面讲解
  • RS485协议驱动开发:项目应用中的代码优化策略
  • 优化I2S音频抗干扰能力:操作指南与实践
  • 基于MATLAB的周期方波与扫频信号生成实现(支持参数动态调整)
  • 手把手教你用Driver Store Explorer清理无效驱动
  • 零成本实现文档智能:本地化 OCR 提取与 AI 处理全流程实战
  • Hyper-V冲突导致HAXM无法安装?解决方案详解
  • 光刻胶在电镀与蚀刻中的角色解析:通俗解释
  • 手把手实现LVGL显示驱动配置流程
  • SMBus协议错误处理机制在电源管理中的影响:系统解析
  • Qwen2.5-7B大模型离线部署指南|vLLM加速落地
  • 基于第三方中转的高效 Sora-2 接口集成方案
  • HY-MT1.5-1.8B 支持多语言神经机器翻译;Med-Banana-50K 提供医学影像编辑基准数据
  • 快速理解USB over Network在Win平台的工作机制
  • Coinstore B.KU 数字金融与 RWA 主题活动圆满举行
  • 板对板连接器解决方案:覆盖消费电子、汽车、工业全领域