3. set 的使用

3. set 的使用

因为在实际工程中,我们不会将具体文件全部写出来,这是一件费力不讨好的事情。

3.1 set 定义变量

在 CMake 文件中,默认的变量数据类型是字符串,如果要用别的类型,需要进行转换

在上面的例子中一共提供了 5 个源文件,假设这 5 个源文件需要反复被使用,每次都直接将它们的名字写出来确实是很麻烦,此时我们就需要定义一个变量,将文件名对应的字符串存储起来,在 CMake 里定义变量需要使用 set

3.1.1 定义文件列表

set 的语法:

# SET 指令的语法是:
# [] 中的参数为可选项, 如不需要可以不写
SET(VAR [VALUE] [CACHE TYPE DOCSTRING [FORCE]])
  • VAR:变量名
  • VALUE :变量值

使用示例:

# 方式1:各个源文件之间使用空格间隔
# set(SRC_LIST main.cpp div.cpp sub,cpp mul.cpp add.cpp)

# 方式2:各个源文件之间使用分号 ; 间隔
set(SRC_LIST main.cpp;div.cpp;sub,cpp;mul.cpp;add.cpp)
add_executable(calc ${SRC_LIST})

3.1.2 指定C++标准

在编写 C++ 程序的时候,可能会用到 C++11、C++14、C++17、C++20 等新特性,那么就需要在编译的时候在编译命令中制定出要使用哪个标准:

g++ *.cpp -std=c++11 -o app

C++标准对应有一宏叫做 DCMAKE_CXX_STANDARD 。在 CMake 中想要指定 C++ 标准有两种方式:

  • 在 CMakeLists 中通过 set 指定:

    set(CMAKE_CXX_STANDARD 17)	# 增加-std=c++17
    set(CMAKE_CXX_STANDARD 20)	# 增加-std=c++20
    
  • 在执行 cmake 命令时候指定:-DXXX 后面的 XXX 就是具体的宏,前面的 D 表示它是一个宏,它在生成 makefile 的时候,会在里面添加上我们指定的版本信息

    # 增加 -std=c++11
    cmake -DCMAKE_CXX_STANDARD=11
    

某些编译器版本较低,默认指定的标准为 C++98,这时候我们最好在 CMakeLists 中指定标准。

3.1.3 指定输出的路径

在 CMake 中指定可执行程序输出的路径,也对应一个宏,叫做 EXECUTABLE_OUTPUT_PATH,它的值还是通过set 命令进行设置:

# set(HOME /home/yuzu/cmake_proj/proj2)
set(HOME ${CMAKE_CURRENT_SOURCE_DIR})	# 获取当前CMakeLists.txt 的路径,赋给HOME
set(EXECUTABLE_OUTPUT_PATH ${HOME}/bin)
  • 第一行:定义一个变量用于存储一个绝对路径(在这里不起作用)
  • 第二行:获取当前CMakeLists.txt 的路径,赋给变量 HOME
  • 第三行:将拼接好的路径值设置给 EXECUTABLE_OUTPUT_PATH

如果这个路径中的子目录不存在,会自动生成,无需自己手动创建

此时我们手动调用 make ,则会在 bin 目录下生成一个可执行文件 calc

tree bin
bin
└── calc

0 directories, 1 file

上述命令可以给动态库指定生成路径,但是一般不这么做,指定动态库生成路径有另一个宏,为:LIBRARY_OUTPUT_PATH,用法和 EXECUTABLE_OUTPUT_PATH 相似

set 比较灵活,可以给自定义变量设置值,也可以获取宏的值。

但是上面的 CMake 设置还是没有解决本质上的问题,因为我们还是要把源文件中的文件都列出来,在这里我们可以使用 CMake 中搜索文件的功能解决。

posted @ 2024-07-15 10:41  kobayashilin1  阅读(13)  评论(0编辑  收藏  举报