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

【cmake学习】find_package 详解

find_package 主要用于查找指定的 package,主要支持两种搜索方法:

  • Config mode:查找 xxx-config.cmake或 xxxConfig.cmake的文件,如OpenCV库的OpenCVConfig.cmake
  • Module mode:查找Findxxx.cmake文件,如OpenCV库中的FindCUDA.cmake

详细的find_package介绍参考链接:find_package详解


目录

一、检索模式

1、Config mode(配置模式)

2、Module mode(模块模式)

二、find_package 的格式及内置变量

1、签名格式

2、find_package 内置变量


一、检索模式

find_package 有两种检索模式,这两种模式存在优先级,如果其中一种检索模式没有找到所需模块,就会启用另一种模式。

不同模式下,find_package 使用的检索路径也会有所不同。

1、Config mode(配置模式)

该模式下查找的是 <lowercasePackageName>-config.cmake 或 <PackageName>Config.cmake的文件。xxx-config.cmake 文件一般是小写开头,XXXConfig.cmake 文件一般是大写开头。

cmake 通过 CMAKE_PREFIX_PATH 设置配置模式的搜索路径:

# CMAKE_PREFIX_PATH 是配置模式的搜索路径
# 方式一
set(CMAKE_PREFIX_PATH 搜索路径)
# 方式二
list(APPEND CMAKE_PREFIX_PATH 搜索路径)

2、Module mode(模块模式)

该模式下查找的是 Find<PackageName>.cmake 的文件。

cmake 通过 CMAKE_MODULE_PATH 设置模块模式的搜索路径:

# CMAKE_MODULE_PATH 是模块模式的默认搜索路径
# 方式一
set(CMAKE_MODULE_PATH xxx) 
# 方式二
list(APPEND CMAKE_MODULE_PATH 搜索路径)

二、find_package 的格式及内置变量

find_package 可以在搜索路径和默认路径(环境变量)中查找指定的库或者模块。无论使用哪种模式,都会设置一个 <PackageName>_FOUND 变量来指示是否找到了package。

1、签名格式

尖括号代表必填内容,中括号里的内容代表选择性填写内容

find_package(<PackageName> [version]     # 指定要查找的库或者模块(版本号可选)[EXACT]     # 要求version完全匹配[QUIET]     # 无论找到与否,都不产生任何提示性消息[REQUIRED]  # 要求必须找到 xxx.cmake,找不到就提示报错[[COMPONENTS] [components...]]  [OPTIONAL_COMPONENTS [components...]] [MODULE]           # 仅使用模块模式[CONFIG|NO_MODULE] # 仅使用配置模式(两种写法是等效的)[GLOBAL][NO_POLICY_SCOPE][BYPASS_PROVIDER]
)

(1) [[COMPONENTS] [components...]]

查找 Package 中的指定模块,COMPONENTS 跟的是一个列表,只要列表中任意一个模块没有被找到,则认为整个 Package 没有被找到即 <PackageName>_FOUND 为 false

(如果存在REQUIRED选项,则可以省略COMPONENTS关键字)

# 如果opencv_core、opencv_highgui任意一者没有被找到
# 则认为 OpenCV 库没有找到
# 即 OpenCV_FOUND 为false
find_package(OpenCV COMPONENTS opencv_core opencv_highgui)

(2) [OPTIONAL_COMPONENTS [components...]] 

OPTIONAL_COMPONENTS 跟的也是一个列表,只要列表中的某一项被找到了,就认为是找到了,即 <PackageName>_FOUND 为 true

# 即便是没找到 opencv_xxx,但是找到了opencv_core 
# 则认为 OpenCV 库已被找到
# 即 OpenCV_FOUND 为true
find_package(OpenCV COMPONENTS opencv_core opencv_highgui opencv_xxx)

 

2、find_package 内置变量

find_package 一般都内置了一些变量:

  • <PackageName>_FOUND:可以判断是否找到对应的包或者模块
  • <PackageName>_INCLUDE_DIR:表示头文件目录(前提是包被找到才会被自动设置)
  • <PackageName>_LIBRARIES:表示库文件

以查找 OpenCV 库为例:

# 检索OpenCV库
find_package(OpenCV REQUIRED)add_executable(main src/main.cpp)
if(OpenCV_FOUND)# 引入头文件目录include_directories(${OpenCV_INCLUDE_DIRS})# 链接库文件target_link_libraries(main ${OpenCV_LIBRARIES})
else(OpenCV_FOUND)message(FATAL_ERROR "OpenCV library not found")
endif()

注意:${OpenCV_LIBRARIES} 只是库名,不代表库目录,相当于在其他地方做了如下操作

set(OpenCV_LIBRARIES opencv_core opencv_calib3d opencv_highgui )
http://www.lryc.cn/news/58942.html

相关文章:

  • WEB攻防-通用漏洞PHP反序列化POP链构造魔术方法原生类
  • Baumer工业相机堡盟工业相机如何通过BGAPISDK里的图像处理库进行图像转换(C++)
  • JD开放平台接口(获得JD商品详情, 按关键字搜索商品,按图搜索京东商品(拍立淘), 获得店铺的所有商品,获取推荐商品列表, 获取购买到的商品订单列表)
  • 上海亚商投顾:沪指震荡反弹 游戏、传媒概念股再度大涨
  • C/C++ 玩转StoneValley库:从入门到精通
  • CentOS7-部署Tomcat并运行Jpress
  • 菜鸟程序员的3年心酸逆袭之旅!今天你对我爱搭不理,明天我让你高攀不起!
  • 【Scala】异常 隐式转换 泛型
  • 1673_MIT 6.828 Homework xv6 lazy page allocation要求翻译
  • 六、Locust之TaskSets详解
  • flask_知识点3_css
  • Redis_概述_特性_IO模型
  • [论文速览] Sparks of Artificial General Intelligence: Early experiments with GPT-4
  • 舔狗日记:学姐生日快到了,使用Python把她的照片做成视频当礼物
  • 从《移动互联网应用程序(App)收集使用个人信息自评估指南》看个人信息保护着力点
  • 电脑0x0000001A蓝屏错误怎么U盘重装系统教学
  • Day939.如何小步安全地升级数据库框架 -系统重构实战
  • 2023 年十大 API 管理趋势
  • 计算机网络微课堂1-3节
  • [Eigen中文文档] Array类与元素操作
  • python学习,全球有哪些特别好的社区推荐呢?
  • LC-1042. 不邻接植花(四色问题(染色法))
  • python实战应用讲解-【numpy科学计算】scikits-learn模块(附python示例代码)
  • 大数据开发必备面试题Spark篇01
  • SpringBoot整合xxl-job详细教程
  • 【MySQL--04】数据类型
  • git 将其它分支的文件检出到工作区
  • 人工智能的最大危险是什么?
  • rk3568点亮E-ink
  • 如何将Springboot项目通过IDEA打包成jar包,并且转换成可执行文件