Valgrind 是 Linux 下检测 C++ 内存泄漏最常用可靠的工具,需编译时加 -g -O0 保证符号表和准确追踪;运行 valgrind --leak-check=full --show-leak-kinds=all 检查,重点关注 “definitely lost” 和 “indirectly lost” 泄漏,并通过调用栈定位源头。

Valgrind 是 Linux 下检测 C++ 程序内存泄漏最常用、最可靠的工具之一。它不依赖编译器特殊选项,只需程序带调试信息(编译时加 -g),运行时用 valgrind 包裹执行即可捕获 malloc/new 未配对释放的问题。
编译时必须加 -g 并禁用优化
Valgrind 需要符号表定位代码行号,否则只显示 ??。同时高优化等级(如 -O2)可能让变量生命周期和内存操作被重排,导致漏报或误报。
- 正确编译命令:g++ -g -O0 -o myapp main.cpp
- 避免使用 -O2/-O3;-O1 一般可接受,但 -O0 最稳妥
- 如果用了 CMake,确保 CMAKE_BUILD_TYPE=Debug,并检查是否启用了 -g
用 memcheck 检测内存泄漏
Valgrind 默认子工具是 memcheck,专用于检测非法内存访问和泄漏。运行后关注结尾的 “HEAP SUMMARY” 和 “LEAK SUMMARY”。
- 基础命令:valgrind --leak-check=full --show-leak-kinds=all ./myapp
- --leak-check=full:显示每处泄漏的调用栈(关键!)
- --show-leak-kinds=all:不忽略 “still reachable” 类型(有些是正常缓存,但初学者建议全看)
- 若程序很快退出,加 --track-origins=yes 可辅助定位未初始化内存来源(非泄漏,但常伴生)
读懂泄漏报告的关键字段
Valgrind 输出中真正要盯的是 “definitely lost” 和 “indirectly lost”。它们代表已丢失且无法访问的堆内存——即典型内存泄漏。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~