通八洲科技

c++怎么查内存泄漏 c++ Valgrind工具使用【教程】

日期:2026-01-02 00:00 / 作者:裘德小鎮的故事
Valgrind 是 Linux 下无需重编译、依赖调试信息即可精准定位内存泄漏的动态分析工具;它通过 --leak-check=full 和 --show-leak-kinds=all 参数报告四类泄漏,其中 definitely lost 表示真实泄漏,源码位置可直接定位修复。

在 C++ 中查内存泄漏,Valgrind 是 Linux 下最可靠、最常用的动态分析工具之一。它不依赖源码编译选项(如 AddressSanitizer 那样需重新编译),只要程序是调试信息完整(带 -g)的可执行文件,就能精准定位 malloc/new 未配对释放的位置。

安装与基础运行

Ubuntu/Debian 系统直接安装:

其中关键参数说明:

读懂 Valgrind 报告的关键字段

典型泄漏报告形如:

==12345== 40 bytes in 1 blocks are definitely lost in loss record 1 of 2
==12345==    at 0x4C2E80F: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==12345==    by 0x4007F2: main (test.cpp:12)

重点关注:

常见误报与规避技巧

Valgrind 对某些系统库或第三方库(如 Qt、OpenGL)可能报出大量 still reachable 或 suppressed 泄漏,不必惊慌:

对比其他常用方法

Valgrind 不是唯一选择,但适合线下深度排查:

Valgrind 的优势在于无需改代码、不干扰运行逻辑、能覆盖多线程和复杂生命周期场景。