mtrace内存泄露检查

来源:互联网 发布:淘宝助手导出csv文件 编辑:程序博客网 时间:2024/04/24 11:34

mtrace是linux下检查内存泄漏的工具之一
 
    它实际上是通过一对函数来检测一段代码是否存在内存泄漏:
    mtrace()与muntrace()。
    它们的原型如下:
    void mtrace(void);
    void muntrace(void);
    头文件为:mcheck.h
 
用法:
   1. 首先确定需要检测那一段代码
   2. 然后再在这段代码的前面调用mtrace(),在这段代码之后调用muntrace()。
   3. 设置环境变量:MALLOC_TRACE,可以在程序编译好后通过命令:
      export MALLOC_TRACE=./log   //其中log是用来存放内存泄漏信息的日志文件名。
      也可以在调用mtrace()之前调用函数设置环境变量:setenv("MALLOC_TRACE", "log", 1);
   4. 编译并运行程序,这样内存泄漏信息就会写到log文件中。
   5. 查看log文件,如:cat log
 
注意: 一般情况下不要调用muntrace, 而让程序自然结束. 因为可能有些释放内存代码要到muntrace之后才运行.
实例:
#include <stdio.h>
#include <error.h>
#include <mcheck.h>
int main(void)
{
    setenv("MALLOC_TRACE", "log", 1);   //设置环境变量MALLOC_TRACE
    mtrace();   //在需要检测的代码段之前调用mtrace函数
    char *str1 = (char*)malloc(10);
     char *str2 = (char*)malloc(10);
    if((NULL == str1) || (NULL == str2))
    {
        perror("can't allocate memory");
    }
    muntrace();    //在需要检测的代码段之后调用muntrace函数
    return 0;
}
将上面的程序编译运行后会在当前目录下产生一个记录=内存泄漏的文件log,其内容如下:
(“+”表示申请的内存,“-”表示释放的内存)
= Start
@ ./test:[0x8048534] + 0x9ed1418 0xa
@ ./test:[0x8048542] + 0x9ed1428 0xa
= End
上面的信息表示:程序分配了两次内存,起内存地址分别是0x9ed1418和0x9ed1428;但并未释放,于是这段程序就存在内存泄漏。
现在我们在示例程序中加上一句:free(str1); 再编译运行后查看log如下:
= Start
@ ./test:[0x8048564] + 0x91ab418 0xa
@ ./test:[0x8048572] + 0x91ab428 0xa
@ ./test:[0x804859c] - 0x91ab418 
= End
上面的信息表示:程序申请了两块内存0x91ab418和0x91ab428,但只释放了内存0x91ab418 。故也存在内存泄漏。
当然如果加上free(str1); 与free(str2);则log内容如下:
= Start
@ ./test:[0x8048564] + 0x809b418 0xa
@ ./test:[0x8048572] + 0x809b428 0xa
@ ./test:[0x804859c] - 0x809b418
@ ./test:[0x80485a4] - 0x809b428
= End
这表示申请的内存都释放掉了,故不存在内存泄漏。

通过解析log文件知道内存泄露的函数
mtrace  执行文件  log  

原创粉丝点击