Valgrind 有效使用需编译加 -g 且禁用优化(-O0),运行时用 --leak-check=full --show-leak-kinds=all 分析泄漏,重点关注 definitely lost 和 indirectly lost;C++ 中 new/delete 必须配对,多线程可用 helgrind。

Valgrind 是 Linux 下最常用的内存调试工具之一,尤其擅长检测 C/C++ 程序中的内存泄漏、非法内存访问、使用未初始化内存等问题。要让它有效工作,关键不是“装上就用”,而是编译、运行、分析三步都得对。
编译时必须加 -g 并禁用优化
Valgrind 需要符号信息才能定位到具体哪一行出问题,所以编译时一定要加 -g;同时,开启优化(如 -O2)会让代码重排、内联、变量被优化掉,导致报告位置不准甚至漏报。推荐的编译命令是:
- g++ -g -O0 -Wall your_code.cpp -o your_program
- 如果用了 CMake,确保
CMAKE_BUILD_TYPE=Debug,并检查是否启用了 -O2(需手动关掉)
用 valgrind --leak-check=full 运行程序
基础命令格式:
- valgrind --leak-check=full --show-leak-kinds=all ./your_program
-
--leak-check=full启用详细泄漏分析 -
--show-leak-kinds=all显示 definitely lost / indirectly lost / possibly lost / still reachable 四类结果 - 加
--track-origins=yes可追查未初始化值的来源(对“Conditional jump or move depends on uninitialised value”这类错误很有用)
看懂关键泄漏分类和常见原因
Valgrind 报告里最值得关注的是前两类:
立即学习“C++免费学习笔记(深入)”;
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~