对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。Linux系统下有一个工具可以帮忙调试,这就是mtrace。mtrace主要能够检测一些内存分配和泄漏的失败等。下面我们来学习一下它的用法(man mtrace)
1.在需要跟踪的程序中需要包含头文件<mcheck.h>,而且在main()函数的最开始包含一个函数调用mtrace()。由于在 main函数的最开头调用了mtrace(),所以该进程后面的一切分配和释放内存的操作都可以由mtrace来跟踪和分析。
2.定义一个环境变量,用来指定一个文件,该文件用来输出log信息。如下的例子:$export MALLOC_TRACE=mymemory.log
这里也可以在程序中设置:setenv("MALLOC_TRACE", "mymemory.log", 1);此语句放在mtrace()前就可以.
3.正常运行程序,此时程序中的关于内存分配和释放的操作都可以记录下来
4.然后用mtrace使用工具来分析log文件。例如:$mtrace testmtrace $MALLOC_TRACE
(其中testmtrace为可执行文件)
见例子:
#include <mcheck.h>
#include <stdio.h>
#include <stdlib.h>
int main()
{
char *hello;
mtrace();
hello = (char*)malloc(20);
sprint