众所周知,c或者c++编写的程序很容易出现内存泄露问题。valgrind是一个很好的工具,可以检测程序中的内存泄露问题。
什么是内存泄露
内存泄露可以分为两种:
一种是,程序中有指针指向通过malloc或者new申请的内存,但是在程序结束前,一直未收回。如果这种内存一直增加的话,可能导致内存耗尽。不过程序结束后系统会自动回收这些内存。
另一种是,通过malloc或者new申请的内存,但是程序中已经没有指针指向申请的内存。程序一直在执行,泄露的内存会越来越多,可能会耗尽程序的堆内存。
如何使用valgrind检测内存泄露
valgrind的使用方式很简单,使用的格式如下:
valgrind 参数 要检测的程序
示例:
$valgrind --leak-check=full ./test
输出结果中有如下字样:
LEAK SUMMARY:
==5578== definitely lost: 0 bytes in 0 blocks
==5578== indirectly lost: 0 bytes in 0 blocks
==5578== possibly lost: 53,201 bytes in 15 blocks
==5578== still reachable: 34,002 bytes in 30 blocks
==5578== suppressed: 0 bytes in 0 blocks
valgrind命令的更多参数可以通过以下命令查看
$valgrind -h
不同内存泄露情况在valgrind中的表现
对于上述的第一种内存泄露的情况,在valgrind的报告中会表示为“still reachable”。
对于第二种情况的内存泄露,在valgrind的报告中会表示为"Directly lost和Indirectly lost"
另外对于valgrind报告中的“possibly lost”,是因为指针没有指向到申请堆的开始。如,c++的string有内存池的概念。如果程序中使用了string,且非正常退出(如使用ctrl+c快捷键终止程序),会报“possibly lost”
关于使用valgrind检测内存泄露更详尽的文档 http://valgrind.org/docs/manual/mc-manual.html#mc-manual.leaks