Valgrind是一个GPL的软件,用于Linux(For x86, amd64 and ppc32)程序的内存调试和代码剖析。尤其对于C/C++程序,可以用它来检测是否有内存泄漏,以及定位内存泄漏的坐标。
Valgrind工具包包含多个工具,如Memcheck,Cachegrind,Helgrind, Callgrind,Massif等。
1) Memcheck
这个工具就是刚说的用来检测内存的家伙啦!它的功能非常强大,可以定位内存泄漏的坐标,下面是它检查的内容:
-
使用未初始化的内存 (Use of uninitialised memory)
-
使用已经释放了的内存 (Reading/writing memory after it has been free’d)
-
使用超过 malloc分配的内存空间(Reading/writing off the end of malloc’d blocks)
-
对堆栈的非法访问 (Reading/writing inappropriate areas on the stack)
-
申请的空间是否有释放 (Memory leaks – where pointers to malloc’d blocks are lost forever)
-
malloc/free/new/delete申请和释放内存的匹配(Mismatched use of malloc/new/new [] vs free/delete/delete [])
-
src和dst的重叠(Overlapping src and dst pointers in memcpy() and related functions
使用时命令为:
Valgrind --tool=memcheck --leak-check=(no|summary|full ) “你的应用程序”
当检测到有内存泄漏时,Valgrind将会把内存泄漏的堆栈信息输出到标准输出,并包含了各个文件名,这样很容易就定位到内存泄漏的位置。
如果你熟悉VS的CMemoryState类,会更容易理解这个问题的。
2)其它工具
本人还没有去试用过其它工具的功能,在此不做介绍,等有亲身体验后再来完善这篇文章。
如果需要了解其它工具的使用,请参考Valgrind的使用说明书。Valgrind的主页为:http://valgrind.org/