首页 > 编程 > C > 正文

cmake 学习笔记

2020-01-26 14:01:07
字体:
来源:转载
供稿:网友

最近接触到一些工程上的代码,都是用cmake来编译的,每次看着CMakeLists.txt 就各种懵逼,决定从0 开始学习

1 set

set(var hello)message(${var})

输出

hello

其实并不是单单输出hello,还有很多其他信息,会生成很多文件

files

2 CMAKE_C(XX)_FLAGS

变量 CMAKE_C_FLAGS 存放的内容会被传给 C 编译器,作用在所有的编译组态上。如果希望只针对特定一种组态有效,可以设定 CMAKE_C_FLAGS_<编译组态>,例如 CMAKE_C_FLAGS_RELEASE、CMAKE_C_FLAGS_DEBUG。
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS}     -Wall -O3 -march=native -Wno-reorder")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -O3 -march=native -Wno-reorder")

编译选项为-Wall O3的优化

其他内部变量:

•CMAKE_C_COMPILER:指定C编译器
•CMAKE_CXX_COMPILER:
•CMAKE_C_FLAGS:编译C文件时的选项,如-g;也可以通过add_definitions添加编译选项
•EXECUTABLE_OUTPUT_PATH:可执行文件的存放路径
•LIBRARY_OUTPUT_PATH:库文件路径
•CMAKE_BUILD_TYPE::build 类型(Debug, Release, ...),
•CMAKE_BUILD_TYPE=Debug
•BUILD_SHARED_LIBS:Switch between shared and static libraries

内置变量的使用:

•在CMakeLists.txt中指定,使用set
•cmake命令中使用,如cmake -DBUILD_SHARED_LIBS=OFF

3 CHECK_CXX_COMPILER_FLAG

检查CXX编译器是否支持给定的flag
必须先include(CheckCXXCompilerFlag)
include(CheckCXXCompilerFlag)
CHECK_CXX_COMPILER_FLAG(<flag> <var>)
e.g.

CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11)CHECK_CXX_COMPILER_FLAG("-std=c++0x"COMPILER_SUPPORTS_CXX0X)if(COMPILER_SUPPORTS_CXX11)  set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")  add_definitions(-DCOMPILEDWITHC11)  message(STATUS "Using flag -std=c++11.") elseif(COMPILER_SUPPORTS_CXX0X)  set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++0x")  add_definitions(-DCOMPILEDWITHC0X)  message(STATUS "Using flag -std=c++0x.")else()  message(FATAL_ERROR "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.")endif()

上面的代码很直接
就是在检查当前编译器是否支持c++11
CHECK_CXX_COMPILER_FLAG 赋值给的var是个bool型

4 add_definitions

添加编译参数
add_definitions(-DDEBUG)

将在gcc命令行添加DEBUG 宏定义 ,那么你就可以在你的源文件里面对DEBUG宏来操作

5 ENV

语法:
  $ENV(VAR)# 读取环境变量 VAR,也可用set对其赋值
eg:
IF(DEFINED ENV{ARM_ARCHITECTURE})#如果是arm的机器

6 list

List 操作

list(LENGTH <list> <output variable>)list(GET <list> <element index> [<element index> ...]   <output variable>)list(APPEND <list> [<element> ...])list(FIND <list> <value> <output variable>)list(INSERT <list> <element_index> <element> [<element> ...])list(REMOVE_ITEM <list> <value> [<value> ...])list(REMOVE_AT <list> <index> [<index> ...])list(REMOVE_DUPLICATES <list>)list(REVERSE <list>)list(SORT <list>)

APPEND 追加元素,懂了吧,这些都是list的操作

7 CMAKE_MODULE_PATH

cmake 进行搜索的modules的list, 它是一个list

8 find_package

这个有点复杂,还是直接看官方文档
还有这个

9 include_directories

增加头文件的搜索路径,相当于指定gcc的-I参数
include_directories([AFTER|BEFORE] [SYSTEM] dir1 [dir2 ...])

10 add_library

add_library(<name> [STATIC | SHARED | MODULE]
            [EXCLUDE_FROM_ALL]
            source1 [source2 ...])

增加库的目录

11 target_link_libraries

target_link_libraries(<target> [item1 [item2 [...]]]
                      [[debug|optimized|general] <item>] ...)

指令 target_link_libraries()用于指定 target 所需要链接的库,还可以有不同的选项。
e.g.

target_link_libraries(myapp  debug -labc  optimized -lxyz  )

myapp 在 debug build 时会链接 libabc.a,在 release build 时会链接 libxyz.a,他们的目录被add_library命令添加进去了

12 add_executable

增加可执行文件(从源文件)
add_executable(<name> [WIN32] [MACOSX_BUNDLE]
               [EXCLUDE_FROM_ALL]
               source1 [source2 ...])

e.g.

add_executable(stereo_euroc Examples/Stereo/stereo_euroc.cc)target_link_libraries(stereo_euroc ${PROJECT_NAME})

stereo_euroc 是要生成的可执行文件,源码是后面的.cc文件,链接后面的库

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选