cmake target_include_directories 详解

news/2024/7/1 5:15:52

在 CMake 中,target_include_directories 命令用于向特定目标(如可执行文件或库)添加包含目录,以便编译器能够找到特定目标所需的头文件。

基本语法

target_include_directories(target_name
    [SYSTEM] [BEFORE]
    directory1
    [directory2 ...]
)
  • target_name:目标名称,可以是通过 add_executable 或 add_library 定义的可执行文件或库的名称。
  • SYSTEM:可选参数,用于将指定的目录标记为系统包含目录,避免编译器产生警告。
  • BEFORE:可选参数,将指定的目录添加到已有的包含目录前面。
  • directory1, directory2, …:要添加到目标的包含目录列表。这些可以是绝对路径或相对于
    CMakeLists.txt 文件的相对路径。

示例用法
假设你的项目目录结构如下:

project/
├── CMakeLists.txt
├── src/
│   ├── main.cpp
│   ├── file1.cpp
│   └── file2.cpp
└── include/
    └── header.h

以下是一个示例 CMakeLists.txt 文件,演示了如何使用 target_include_directories 将 include 目录添加到 MyExecutable 目标中:

cmake_minimum_required(VERSION 3.10)
project(MyProject)

# 设置 C++ 标准
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED True)

# 添加可执行文件
add_executable(MyExecutable
    src/main.cpp
    src/file1.cpp
    src/file2.cpp
)

# 添加包含目录
target_include_directories(MyExecutable PUBLIC
    include
)

# 查找第三方库 LibXYZ
find_package(LibXYZ REQUIRED)

# 将 LibXYZ 的包含目录添加到 MyExecutable 目标中
target_include_directories(MyExecutable PRIVATE
    ${LibXYZ_INCLUDE_DIRS}
)

# 设置第三方库 LibXYZ 的路径
set(LibXYZ_INCLUDE_DIRS "/path/to/LibXYZ/includes")

# 将 LibXYZ 的包含目录添加到 MyExecutable 目标中
target_include_directories(MyExecutable PRIVATE
    ${LibXYZ_INCLUDE_DIRS}
)

注意事项

  1. 包含目录:
    • 使用 target_include_directories 命令来指定要添加到目标的包含路径。
    • 在示例中,通过 PUBLIC 关键字将 include 目录添加为 MyExecutable 目标的公共包含目录。这意味着MyExecutable 及其依赖项(如果有)都可以访问这些头文件。
  2. 多目录添加:
    • 可以将多个目录添加到 target_include_directories 命令中,以列出所有需要的包含路径。
  3. 路径类型:
    • 目录可以是绝对路径或相对于 CMakeLists.txt 文件的相对路径。
  4. 影响范围:
    • 使用 PUBLIC、PRIVATE 或 INTERFACE 关键字可以控制包含路径的传递性,详细说明如下:
      • PUBLIC:包含目录将传递给目标和目标的用户。
      • PRIVATE:包含目录仅传递给目标本身。
      • INTERFACE:包含目录仅传递给目标的用户。

通过正确配置包含目录,可以确保编译器能够正确找到和包含项目中需要的头文件,这对于构建和管理大型项目尤为重要。


http://lihuaxi.xjx100.cn/news/2215655.html

相关文章

给类设置serialVersionUID

第一步打开idea设置窗口(setting窗口默认快捷键CtrlAltS) 第二步搜索找到Inspections 第三步勾选主窗口中Java->Serializations issues->下的Serializable class without serialVersionUID’项 ,并点击“OK”确认 第四步鼠标选中要加…

JavaScript 逻辑赋值运算符(=,||=,??=)与可选链运算符(?. ??)

一、 短路运算 短路运算是一种常见的逻辑运算方式,其核心机制是在运算过程中进行一些优化和简化,从而提高计算效率和减少资源消耗。特别是在处理逻辑与(&&)和逻辑或(||)运算时,如果左侧…

搭建k8s集群报错unknown command “\u00a0“ for “kubeadm init“

搭建k8s报错unknown command “\u00a0” for “kubeadm init” 网上搜了一下,是因为复制过来的命令前面包含了空格,将复制的命令放到idea可以清楚看到几个命令前面有空格,删除掉就好了,记录一下

【电路笔记】-共基极放大器

共基极放大器 文章目录 共基极放大器1、概述2、等效电路3、电流增益4、输入阻抗5、输出阻抗6、电压增益7、示例:电压、电流和功率增益8、总结1、概述 在本文中,我们将介绍双极晶体管放大器的最后一种拓扑,称为共基极放大器 (CBA)。 下面的图 1 显示了 CBA 的电气图,此处没…

【编程语言】Python平台化为何比Java差?

人不走空 🌈个人主页:人不走空 💖系列专栏:算法专题 ⏰诗词歌赋:斯是陋室,惟吾德馨 目录 🌈个人主页:人不走空 💖系列专栏:算法专题 ⏰诗词歌…

jumpserver的入门与实践

Jumpserver 是一个开源的堡垒机系统,它基于 Python 编写,使用 Django 框架,提供了审计、认证、授权、资产和会话管理等功能。以下是 Jumpserver 的入门与实践的基本步骤: 入门 了解Jumpserver: 访问 Jumpserver 官网 …

基于SSM+Jsp的列车票务信息管理系统

开发语言:Java框架:ssm技术:JSPJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包…

cmake aux_source_directory详解

在 CMake 中,aux_source_directory 命令用于将指定目录中的源文件列表添加到一个变量中。这对于需要自动发现目录中所有源文件的情况非常有用,特别是在构建测试或动态加载模块时。 基本语法 aux_source_directory(dir variable)dir:源文件所…