用mtrace检查内存泄露

来源:互联网 发布:tensorflow 二范数 编辑:程序博客网 时间:2024/04/19 12:14
 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

这表示申请的内存都释放掉了,故不存在内存泄漏。

 

通过命令:mtrace log文件 可以解析内存泄露日志