cmake:设置编译选项的讲究(add_compile_options和CMAKE_CXX_FLAGS的区别)

本文介绍了在CMake脚本中如何正确地设置编译选项,包括使用add_compile_options和set命令的区别,以及如何针对不同类型的编译器进行配置。

在cmake脚本中,设置编译选项可以通过add_compile_options命令,也可以通过set命令修改CMAKE_CXX_FLAGSCMAKE_C_FLAGS
使用这两种方式在有的情况下效果是一样的,但请注意它们还是有区别的:
add_compile_options命令添加的编译选项是针对所有编译器的(包括c和c++编译器),而set命令设置CMAKE_C_FLAGSCMAKE_CXX_FLAGS变量则是分别只针对c和c++编译器的。

例如下面的代码

#判断编译器类型,如果是gcc编译器,则在编译选项中加入c++11支持
if(CMAKE_COMPILER_IS_GNUCXX)
	add_compile_options(-std=c++11)
	message(STATUS "optional:-std=c++11")	
endif(CMAKE_COMPILER_IS_GNUCXX)

使用add_compile_options添加-std=c++11选项,是想在编译c++代码时加上c++11支持选项。但是因为add_compile_options是针对所有类型编译器的,所以在编译c代码时,就会产生如下warning

J:\workspace\facecl.gcc>make b64
[ 50%] Building C object libb64/CMakeFiles/b64.dir/libb64-1.2.1/src/cdecode.c.obj
cc1.exe: warning: command line option ‘-std=c++11’ is valid for C++/ObjC++ but not for C
[100%] Building C object libb64/CMakeFiles/b64.dir/libb64-1.2.1/src/cencode.c.obj
cc1.exe: warning: command line option ‘-std=c++11’ is valid for C++/ObjC++ but not for C
Linking C static library libb64.a
[100%] Built target b64

虽然并不影响编译,但看着的确是不爽啊,要消除这个warning,就不能使用add_compile_options,而是只针对c++编译器添加这个option。
所以如下修改代码,则警告消除。

#判断编译器类型,如果是gcc编译器,则在编译选项中加入c++11支持
if(CMAKE_COMPILER_IS_GNUCXX)
	set(CMAKE_CXX_FLAGS "-std=c++11 ${CMAKE_CXX_FLAGS}")
	message(STATUS "optional:-std=c++11")	
endif(CMAKE_COMPILER_IS_GNUCXX)

举一反三,我们就可以想到,add_definitions这个命令也是同样针对所有编译器,一样注意这个区别。

参考资料:
https://cmake.org/
https://cmake.org/cmake/help/v3.1/command/add_compile_options.html
https://cmake.org/cmake/help/v3.1/command/add_definitions.html
https://cmake.org/cmake/help/v3.1/command/set.html
https://cmake.org/cmake/help/v3.1/variable/CMAKE_LANG_FLAGS.html

### CMake设置 `CMAKE_CXX_FLAGS` 为 `-pthread` 的作用与意义 在 CMake 配置中,`set(CMAKE_CXX_FLAGS "-pthread")` 的主要作用是向编译器传递 `-pthread` 参数,从而启用 POSIX 线程(POSIX Threads,简称 pthreads)的支持。以下详细说明其作用使用场景: #### 1. **`-pthread` 的功能** `-pthread` 是一个编译选项,主要用于指示编译链接器在构建程序时支持多线程编程[^1]。具体来说,它会执行以下操作: - **头文件包含**:确保编译器正确包含与 POSIX 线程相关的头文件。 - **库链接**:将程序链接到系统提供的 pthread 库,使得程序能够调用 pthread API(如 `pthread_create`、`pthread_join` 等)[^2]。 - **线程安全的全局变量初始化**:某些编译器(如 GCC Clang)会根据 `-pthread` 选项调整全局变量的初始化方式,以确保线程安全性。 #### 2. **代码示例** 以下是一个简单的多线程程序,并展示如何在 CMake 中配置 `-pthread`: ```cpp // main.cpp #include <iostream> #include <pthread.h> void* thread_function(void* arg) { std::cout << "Thread is running" << std::endl; return nullptr; } int main() { pthread_t thread; pthread_create(&thread, nullptr, thread_function, nullptr); pthread_join(thread, nullptr); return 0; } ``` 对应的 CMakeLists.txt 文件如下: ```cmake cmake_minimum_required(VERSION 3.5) project(MultiThreadExample) # 设置编译选项-pthread set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread") # 添加可执行文件 add_executable(MultiThreadExample main.cpp) ``` #### 3. **使用场景** `-pthread` 通常用于需要多线程支持的场景,例如: - **并发任务处理**:当程序需要同时运行多个任务时,可以使用 pthread 创建多个线程来并行处理[^3]。 - **异步操作**:在等待 I/O 操作或其他耗时任务完成的同时,可以继续执行其他任务。 - **性能优化**:通过多线程充分利用多核 CPU 的计算能力,提升程序性能。 #### 4. **注意事项** - 如果程序不涉及多线程编程,则无需添加 `-pthread` 选项,因为这可能会引入不必要的开销。 - 在某些系统上(如 Linux),即使未显式指定 `-pthread`,链接器也可能自动链接 pthread 库。然而,为了保证跨平台兼容性,建议始终显式设置选项[^1]。 - 使用 `-pthread` 时,应确保目标平台支持 POSIX 线程标准。如果目标平台不支持 pthread(如某些嵌入式系统),则需要寻找替代方案。 #### 5. **与其他标志结合** `-pthread` 可以与其他编译器标志结合使用,例如调试信息 (`-g`) 或优化选项 (`-O3`)。以下是一个综合示例: ```cmake set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread -g -O3") ``` 此配置表示启用 POSIX 线程支持、生成调试信息以及启用最高级别的优化。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

10km

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值