CmakeList文件常见命令含义和用法

  1. cmake_minimum_required 指定cmake最小版本
#命令可选,如果 CMakeLists.txt 文件中使用了高版本cmake命令,需要加上这样一行,提醒用户升级到该版本之后再执行cmake,以防版本不满足导致编译失败。
cmake_minimum_required(VERSION 2.6)
  1. project 设置项目名称
#命令可选,它会引入两个变量 yolov5_BINARY_DIR和yolov5_SOURCE_DIR,
#同时,cmake 自动定义了两个等价的变量 PROJECT_BINARY_DIR 和 PROJECT_SOURCE_DIR。
PROJECT_BINARY_DIR = 全路径/build,PROJECT_SOURCE_DIR = 全路径/src
project(yolov5)
  1. add_definitions 添加编译器命令行标志
    1)通常的情况下我们使用其来添加预处理器定义
add_definitions(-std=c++11)
add_definitions(-Og -pthread)

2)结合option使用,控制代码编译开关的开启和关闭。
首先cpp代码为

#ifdef BOOSTON
#include <boost/thread.hpp>  
#include "boost/thread/mutex.hpp"
#endif

对应的cmakelist.txt为

option(USEBOOST "run with boost" OFF)
IF(USEBOOST)
    add_definitions(-DBOOSTON)
ENDIF(USEBOOST)

编译的时候可以设置USEBOOST开启或者关闭

cmake -DBOOSTON=1 ..
cmake -DBOOSTON=0 ..
  1. set / list 设置别名(赋值)
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_BUILD_TYPE Debug)
set(SRC_LIST yolo.cpp)
add_executable(yolo ${SRC_LIST})
  1. message 打印信息
    message(${SOURCE_DIR})
    message(“the system is ubuntu”)
  2. include_directories 添加第三方库包含的目录(即找头文件)
include_directories(/usr/local/cuda/include)
#路径多的时候也可以写成
include_directories(
        ${PROJECT_SOURCE_DIR}/ina
        ${PROJECT_SOURCE_DIR}/inb
        ${PROJECT_SOURCE_DIR}/inc
        )
  1. link_directories 添加需要链接的库文件目录(即找 .so库文件)
  link_directories(/usr/local/cuda/lib64)
  1. aux_source_directory 搜索所有的 cpp 文件
aux_source_directory(./srca SRCA_LIST)
aux_source_directory(./srcb SRCB_LIST)
aux_source_directory(./srcc SRCC_LIST)
  1. find_package 当编译一个需要使用第三方库的软件时,需要知道其头文件和库文件的目录,可以通过该命令查找
find_package(<PackageName> [version] [EXACT] [QUIET] [REQUIRED])

找到后,默认头文件路径PackageName_INCLUDE_DIR,库文件路径PackageName_LIBRARY。
version: 版本合适(大版本号相同)
EXACT: 版本必须一致
QUIET: 没找到包也不会报错
REQUIRED: 必须找到该包,否则停止
例如:

find_package(CUDA REQUIRED)
include_directories($ {CUDA_INCLUDE_DIR}) 
link_directories($ {CUDA__LIBRARY})
  1. add_library 指定编译yolov5 的链接库
add_library(yolov5 ${SRCA_LIST} ${SRCB_LIST} ${SRCC_LIST})
  1. target_link_libraries 对 add_library 或 add_executable 生成的文件进行链接操作
target_link_libraries(myplugins nvinfer cudart)
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
CMakeLists.txt文件是用于配置CMake构建系统的文件,可以用来指定项目的编译选项、依赖库、生成的可执行文件或动态库等信息。在CMakeLists.txt文件中,可以使用一系列的CMake命令来描述项目的构建过程。常见CMake命令包括add_executable、add_library、target_link_libraries等,这些命令可以用来添加可执行文件或库,并指定它们的源文件、依赖库等信息。通过配置CMakeLists.txt文件后,我们可以使用cmake命令生成Makefile文件,然后使用make命令进行编译工作,最终得到可执行文件或动态库。 CMakeLists.txt文件的编写可以根据具体项目的需求进行灵活配置,但通常包括以下几个常见的部分: 1. 使用cmake_minimum_required命令指定CMake的最低版本要求。 2. 使用project命令指定项目名称。 3. 使用add_executable或add_library命令添加可执行文件或库,并指定源文件。 4. 使用target_link_libraries命令添加依赖库。 5. 使用set命令设置编译选项或定义变量。 6. 使用include_directories或target_include_directories命令指定头文件路径。 7. 使用link_directories或target_link_directories命令指定库文件路径。 8. 使用install命令指定安装规则。 以上是CMakeLists.txt文件的一般编写方式和常见命令用法,具体的编写方式和命令使用取决于项目的需求。 在CMakeLists.txt文件中,可以使用add_definitions命令定义预处理宏。add_definitions的功能和C/C++中的#define是类似的,可以用来定义一些编译时的宏,从而在源代码中使用#ifdef和#ifndef等条件编译语句进行条件判断。例如,在CMakeLists.txt中使用add_definitions命令定义了TEST_IT_CMAKE宏后,源文件中可以通过#ifdef TEST_IT_CMAKE来判断是否定义了该宏,并执行相应的代码。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Cmakelist知识总结](https://blog.csdn.net/niewei120/article/details/127209564)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [CMakeLists入门](https://blog.csdn.net/weixin_45626706/article/details/121191635)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CV温故知新

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值