使用memwatch跟踪linux内存泄漏

参考:
http://blog.csdn.net/kehyuanyu/article/details/25217907
http://blog.sina.com.cn/s/blog_590be5290102w5ve.html
根据log可以查找出申请了却没有释放内存的行号。
一、简介
memwatch可以跟踪程序中的内存泄漏和错误,能检测双重释放(double-free)、错误释放(erroneousfree)、没有释放的内存(unfreed memory)、溢出 (Overflow) 、下溢(Underflow)等。
下载地址:
http://www.linkdata.se/sourcecode/memwatch/
解压后,得到源码 memwatch.c 和 memwatch.h

二、安装及使用
memwatch根本是不需要安装的,因为它只是一组C程序代码。需要做的是:
1、在代码中加入 memwatch.c 和 memwatch.h,一起编译、链接
2、编译时定义宏 DMEMWATCH、DMW_STDIO,即在编译程序时加上选项-DMEMWATCH-DMW_STDIO

三、例子
int main(int argc,char **argv)
{
    int i = 0;
    char *p;

    mwInit();  //执行memwatch的初始化工作。虽然memwatch有在第一次使用时能够自动装载,但作者还是建议我们使用该函数。

    p = malloc(100);
    p = malloc(200);
    free(p);

   for(i=0;i<5;i++)
    {
       p = malloc(50);
       if(p == NULL)
       {
          printf("can't malloc memory for test,num:%d\n",i);
          continue;
       }

       if((i%2) == 0)
       {
          free(p);
           p =NULL;
       }
    }

    mwTerm();  //执行memwatch的清除工作。当我们使用了mwInit()时,就必须使用该函数来终止memwatch的工作。

    return 1;
}

运行程序,会在当前目录生产memwatch.log文件,内容如下:
============= MEMWATCH 2.71 Copyright (C) 1992-1999 JohanLindh =============

Started at Wed Mar  9 14:52:14 2016

Modes: __STDC__ 64-bit mwDWORD==(unsigned long)
mwROUNDALLOC==8 sizeof(mwData)==32 mwDataSize==32


Stopped at Wed Mar  9 14:52:14 2016

unfreed: <9> ../main.c(26), 50 bytes at 0x855c3a0  {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE................}
unfreed: <6> ../main.c(26), 50 bytes at 0x855c268  {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE................}
unfreed: <1> ../main.c(20), 100 bytes at 0x855c1d0  {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE................}

Memory usage statistics (global):
 N)umber of allocations made: 7
 L)argest memory usage     : 300
 T)otal of all alloc() calls: 550
 U)nfreed bytes totals     : 200

参考进行修改代码。

你可能感兴趣的:(解BUG笔记)