C++代码覆盖率测试需用gcc的-fprofile-arcs和-ftest-coverage插桩编译,运行生成.gcda数据,再通过lcov过滤整合并生成HTML报告;编译禁用优化,确保.gcno与.gcda同目录且路径无软链接。

在 C++ 项目中做代码覆盖率测试,核心是用 gcc 的 -fprofile-arcs -ftest-coverage 编译插桩,运行程序生成 .gcda 数据,再用 gcov 解析为行级覆盖报告。真正实用的工程化流程,离不开 lcov 整合多文件、过滤头文件/第三方代码,并生成带样式的 HTML 报告。
编译时开启覆盖率插桩
必须用 gcc 或 g++(Clang 也支持类似选项,但 gcov/lcov 生态主要适配 GCC),且不能开启优化(如 -O2)——否则插桩可能被优化掉,导致覆盖率失真。
- 编译命令加两个关键 flag:
-fprofile-arcs -ftest-coverage - 链接时也要加
-fprofile-arcs(否则会报 undefined reference 到__gcov_flush等符号) - 推荐统一用
cmake管理:在CMakeLists.txt中设置set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fprofile-arcs -ftest-coverage"),并确保CMAKE_BUILD_TYPE为Debug或RelWithDebInfo,禁用-O2/-O3
运行程序生成 .gcda 覆盖数据
插桩后的可执行文件每次运行,都会在对应源文件目录下生成 .gcda 文件(Coverage Data)。注意:.gcda 是增量写入,多次运行会累加统计;若想重跑覆盖率,需手动删除旧 .gcda(或用 lcov --zerocounters)。
- 确保程序正常退出(非 kill/segfault),否则部分计数器可能未刷新到磁盘
- 如果程序是 daemon 或 fork 多进程,需在退出前显式调用
__gcov_flush()(需#include <gcov.h></gcov.h>),或设置环境变量GCOV_PREFIX避免权限/路径问题 - 单元测试建议用
ctest或脚本批量执行,保证所有测试用例都跑过
用 lcov 提取、过滤并生成 HTML 报告
gcov 本身只对单个源文件输出文本报告,而 lcov 是基于它的封装工具,专为项目级覆盖率设计。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~