内存泄漏分析
当以前分配的一片内存不再需要使用或无法访问时,但是却并没有释放它,那么对于该进程来说,会因此导致总可用内存的减少,这时就出现了内存泄漏memory leak。在编程实践中,往往用到较多的是动态的内存分配,这样在程序运行的时候分配内存,而不是在创建进程的时候就分配内存,这大大提高了内存的使用率。在复杂、大型的项目程序中,很可能出现内存泄露,我们可以尽量减少内存泄露,因为这样我们的程序跑起来才更安全。
广义上的内存泄露可以是增加不必要的内存使用,但是更精确的定义是:对内存失去了控制,因而造成了内存的浪费。我们一般说的内存泄露是堆内存泄露,堆内存是可以动态分配的(大小是任意的,在程序运行期间决定的)。使用完后必须显式释放的内存。应用程序一般使用malloc,calloc,realloc,new等函数从堆中分配到一块内存,使用完后,程序必须负责相应的调用free或delete释放该内存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。
一个简单的检测内存泄露的程序例子:
memory-leak.c文件
#include <stdio.h>
int main (void)
{
mtrace();
malloc(10);
malloc(22);
return 0;
}
生成调试的二进制文件(加上调试参数 -g):
gcc memory-leak.c -g -o memory
指定trace的文件名
export MALLOC_TRACE=a.log
调试,检查是否发生了内存泄露
unset MALLOC_TRACE
mtrace a.out a.log
得到的结果:
Memory not freed:
------------------------------------
Address Size Caller
0x00000000022e5460 0xa at /bsdocfs/memory-leak.c:7
0x00000000022e5480 0x16 at /bsdocfs/memory-leak.c:8
说明有内存泄露,并且指出了在程序的位置。