Cmake01-基础知识

158 阅读2分钟

Cmake要点

  • 检测编译环境并且生成build目录在build目录下生成makefile文件等文件
cmake -B build 变量

变量如下:

变量名意义
-DCMAKE_INSTALL_PREFIX安装路径
-DCMAKE_BUILD_TYPE编译类型 RELEASE 或者DEBUG
  • -G用来指定生成器,例如-G"Unix Makefiles"、-G"Visual Studio 2019 、-G"mac xcode "等,请注意,一旦使用之后,会在CMakeCache.txt文件记录下来,除非删除该文件,否则会沿用之前指定的构建平台
  • --build命令用来将调用与构建平台相关的构建命令,例如cmake --build .在linux平台相当于执行
cmake .
make

还可以在此参数后使用--target指定make的参数,cmake --build . --target all即相当于:

cmake .
make all
  • -G指定ninja生成器比原始的makefile更快
cmake --build -G ninja

性能对比;ninja>makefile>MSBuild

  • 指定C++标准,示例为指定C++ 11
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED True)
  • 增加库

在当前构建目录新建一个目录mymath来用于存在我们提供的库文件源代码,在mymath下新建mysqrt.h、mysqrt.cpp、CMakeLists.txt三个文件,内容分别如下

# mymath/CMakeLists.txt
cmake_minimum_required(VERSION 3.10)
add_library(mymath mysqrt.cpp)

// mymath/mysqrt.h
double mysqrt(double x);

// mymath/mysqrt.cpp
#include <cmath>
#include <iostream>
#include "mysqrt.h"
double mysqrt(double x) {
    std::cout << "use my sqrt..." << std::endl;
    return std::sqrt(x);
}

上层目录的CMakeLists.txt的文件需要增加如下内容,一是包含mymath的目录,二是将生成的mymath库链接到最后的可执行文件;可以通过一个开关来打开或者关闭,也可在cmake命令中加入-D参数来传入开关选项(宏定义)

option(USE_MYMATH "Use mymath replace standard libs..." ON) #通过option传递开关
if(USE_MYMATH)
    add_subdirectory(mymath)
    list(APPEND EXTRA_LIBS mymath)
    list(APPEND EXTRA_INCLUDES "$(PROJECT_SOURCE_DIR)/mymath")
endif()
target_link_libraries(targetname ${EXTRA_LIBS})

通过cmake命令传入:

#使用mymath库
cmake . -D USE_MYMATH=ON
#不使用mymath库
cmake . -D USE_MYMATH=OFF
  • 几个对库/可执行文件使用的命令(以target_开头)

第一个:target_include_directories

当编译目标文件时候,增加所需要的头文件目录,用法如下
target_include_directories( [SYSTEM] [BEFORE]
<INTERFACE|PUBLIC|PRIVATE> [items1...]
[<INTERFACE|PUBLIC|PRIVATE> [items2...] ...])
需要注意的时,命令中的第一个参数target必须是已经使用add_library()或者add_executable()命令指定的target,并且不能是一个别名target.
使用这个命令来改造mymah目录下的CMakeLists.txt,这样就不用在上一级的目录指定包含mymath的目录也能找到该目录下的头文件,这样的好处是只要在上级目录用add_subdirectories()添加对该目录的CMakeLists.txt的处理之后,不需要添加每个需要使用文件夹,以便能找到头文件。

#mymath/CMakeLists.txt

#在最后一行加入
target_include_directories(mymath INTERFACE ${CMAKE_CURRENT_SOURCE_DIR})

第二个:target_compile_definitions

编译目标文件时,添加一些预处处理编译选项,例如对宏的定义。
target_compile_definitions(target PUBLIC -DMYMATH)

第三个:target_compile_options

编译目标文件时,增加编译选项,这个命令可以增加任何选项,使用范围很广,但是增加目录或者预处理选项还是推荐target_include_directories()和target_compile_definitions()。

第四个:target_link_libraries

当需要链接到目标文件或者依赖文件时,指定库或标记。

第五个:install命令,当执行make install的时候,会将CMakeLists.txt中的install内容部署到系统相应的位置

install(TARGETS target DESTINATION bin)
install(TARGETS target_lib DESTINATION lib)
install(FILES headers DESTINATION include)