开源项目学习(6)---- CMake 可执行文件生成

2024-06-10 13:28

本文主要是介绍开源项目学习(6)---- CMake 可执行文件生成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CMake 基础DEMO

标题

    • CMake 基础DEMO
      • 可执行文件的生成
        • 最简单的可执行文件实例
        • 使用变量定义生成目标
        • 添加宏定义
        • 设置可执行文件的路径
        • 自动寻找依赖库
      • 打印信息
      • CMake 常见编译选项

可执行文件的生成

最简单的可执行文件实例
cmake_minimum_required(VERSION 3.22)
project(tonydemoproject)add_executable(testdemo main.cpp)

如果要添加多个文件到可执行文件中:

cmake_minimum_required(VERSION 3.22)
project(tonydemoproject)add_executable(testdemo main.cpp basicStringDemo.cpp basicStringDemo.h)
使用变量定义生成目标

也可以使用变量的方法定义:

file( GLOB APP_SOURCES RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} *.cpp )
message(Info "CMAKE_CURRENT_SOURCE_DIR is ${CMAKE_CURRENT_SOURCE_DIR}")
message(Info "APP_SOURCES is ${APP_SOURCES}")
add_executable(testdemo ${APP_SOURCES})

输出结果如下:

InfoCMAKE_CURRENT_SOURCE_DIR is /home/tonychen/Documents/visualstudiocode_demo
InfoAPP_SOURCES is basicStringDemo.cpp;cplusCastDemo.cpp;main.cpp
-- Configuring done
-- Generating done
-- Build files have been written to: /home/tonychen/Documents/visualstudiocode_demo/cmake_build

上面的 message 用于打印出信息,第一个参数的含义如下:

() = 重要消息;STATUS = 非重要消息;WARNING = CMake 警告, 会继续执行;AUTHOR_WARNING = CMake 警告 (dev), 会继续执行;SEND_ERROR = CMake 错误, 继续执行,但是会跳过生成的步骤;FATAL_ERROR = CMake 错误, 终止所有处理过程;
添加宏定义
......
add_definitions(-DTDEBUG)
add_executable(testdemo ${APP_SOURCES})

上面的 CMakeLists.txt 中就会自动添加 TDEBUG的宏

设置可执行文件的路径

设置可执行文件输出目录的方法如下:

.....set (EXECUTABLE_OUTPUT_PATH ./bin/)
add_definitions(-DTDEBUG)
add_executable(testdemo ${APP_SOURCES})

编译时就会看到可执行文件的路径变化:
Consolidate compiler generated dependencies of target testdemo
[ 25%] Building CXX object CMakeFiles/testdemo.dir/main.cpp.o
[ 50%] Linking CXX executable bin/testdemo
[100%] Built target testdemo

自动寻找依赖库

cmake 提供了一个通过 类unix 系统都有的 pkg-config 命令自动查找依赖的库和对应头文件的操作,看实例如下:

cmake_minimum_required(VERSION 3.21)
project(basicc_demo C)set(CMAKE_C_STANDARD 11)find_package(PkgConfig REQUIRED)
pkg_search_module(EGL REQUIRED egl)
pkg_search_module(GLESv2 REQUIRED glesv2)# 假设EGL_FOUND 打印出具体的 EGL 和 GLESv2 的信息
if(EGL_FOUND)
MESSAGE(WARNING "Found Packages EGL")
MESSAGE(WARNING "print ${EGL_INCLUDE_DIRS}")
MESSAGE(WARNING "print ${GLESv2_LIBRARIES}")
endif()add_executable(basicc_demo main.ctestbasicCOperator.htestbasicCOperator.ctestbasicPointer.ctestbasicPointer.hccommon.hbasicCVector.cbasicCVector.h)

pkg_search_module( REQUIRED|QUIET [ ])
pkg_search_module 这个函数中,参数意义如下:

<prefix>: 这是一个变量前缀,CMake 会创建一些变量来表示找到模块的信息,这些信息会以这个前缀作为开头,
比如前缀是 FOO,那么可能会创建变量 FOO_FOUND,FOO_INCLUDE_DIRS FOO_LIBRARIES
REQUIRED 或 QUIET:
REQUIRED 表示这个模块是必须找到的,如果找不到,CMake 将会停止配置过程并报错。
QUIET 表示如果找不到模块,CMake 不会发出警告或错误,配置过程会继续。
<name>: 这是你要查找的模块的名称,通常是 pkg-config 的模块名称。

打印信息

在 CMake 中,message() 函数用于在构建过程中输出信息性、警告性或错误性的消息,基本的使用方法如下:

message([<mode>] "message to display" ...)

mode 是可选参数,如果不提供,默认是 STATUS 类型,mode 的可选参数如下:
STATUS: 表示一条状态消息,这是默认模式
SEND_ERROR: 表示一条错误消息,这会导致 CMake 继续处理,但最终配置步骤会失败
FATAL_ERROR: 表示一条致命错误消息,CMake 会立即停止处
WARNING: 表示一条警告消息,CMake 会继续处理
AUTHOR_WARNING: 表示一条仅对项目作者可见的警告消息,类似于 WARNING,但不会警告最终用户

CMake 常见编译选项

下面是一些常用的 CMake 编译选项,以及经过验证:

  1. -DCMAKE_BUILD_TYPE: 设置构建类型,如 DebugReleaseRelWithDebInfoMinSizeRel

  2. -DVAR=value: 定义一个变量及其值,可以在 CMakeLists.txt 中使用该变量

  3. -H -S: 指定源代码目录,两者的含义相同

  4. -B: 指定生成构建系统文件的目录,与 -S 选项结合使用 比如:
    cmake -S /xxxx/src -B ./cmake_build_dir

  5. -D<CMAKE_VARIABLE>=<value>: 设置 CMake 内置变量的值,如 CMAKE_C_COMPILERCMAKE_CXX_COMPILER

  6. --build pathtobuild 在生成编译系统文件的基础上进行编译,路径和 -B 选项生成的一致,此命令会进行编译操作

tonychen@tonychen-PC:~/CLionProjects/basicc_demo$ cmake --build ./cmake-build-debug/
Consolidate compiler generated dependencies of target basicc_demo
[100%] Built target basicc_demo
  1. --target xxx 制定生成的目标,通常和 --build 选项配合使用,注意这里的目标要和 CMakeLists.txt 中的保持一致,此命令用于 CMakeLists.txt 包含多目标的情形

  2. -DCMAKE_INSTALL_PREFIX 设置安装的路径前缀
    cmake -DCMAKE_INSTALL_PREFIX=/path/to/install

9.-DBUILD_SHARED_LIBS=ON: 默认构建共享库(动态库)

  1. -DBUILD_STATIC_LIBS=ON: 构建静态库
    cmake -DBUILD_STATIC_LIBS=ON

这篇关于开源项目学习(6)---- CMake 可执行文件生成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1048284

相关文章

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

浅析如何使用Swagger生成带权限控制的API文档

《浅析如何使用Swagger生成带权限控制的API文档》当涉及到权限控制时,如何生成既安全又详细的API文档就成了一个关键问题,所以这篇文章小编就来和大家好好聊聊如何用Swagger来生成带有... 目录准备工作配置 Swagger权限控制给 API 加上权限注解查看文档注意事项在咱们的开发工作里,API

配置springboot项目动静分离打包分离lib方式

《配置springboot项目动静分离打包分离lib方式》本文介绍了如何将SpringBoot工程中的静态资源和配置文件分离出来,以减少jar包大小,方便修改配置文件,通过在jar包同级目录创建co... 目录前言1、分离配置文件原理2、pom文件配置3、使用package命令打包4、总结前言默认情况下,

python实现简易SSL的项目实践

《python实现简易SSL的项目实践》本文主要介绍了python实现简易SSL的项目实践,包括CA.py、server.py和client.py三个模块,文中通过示例代码介绍的非常详细,对大家的学习... 目录运行环境运行前准备程序实现与流程说明运行截图代码CA.pyclient.pyserver.py参

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

IDEA运行spring项目时,控制台未出现的解决方案

《IDEA运行spring项目时,控制台未出现的解决方案》文章总结了在使用IDEA运行代码时,控制台未出现的问题和解决方案,问题可能是由于点击图标或重启IDEA后控制台仍未显示,解决方案提供了解决方法... 目录问题分析解决方案总结问题js使用IDEA,点击运行按钮,运行结束,但控制台未出现http://

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机