linux下检查内存泄露的工具 mtrace

最令linux程序员头疼的莫过于内存泄露了,即使你是在优秀的程序员,你也不能保证所以的malloc操作都有对应的free,那必要的工具就是必不可少的了。在一般的linux发行版中,有一个自带的工具可以很方便的替你完成这些事,这个工具就是mtrace。此函数也只是检查malloc not free 的情况(我觉得)。

下面是它的用法.

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#include <mcheck.h>
 
 
int main(){
    setenv("MALLOC_TRACE", "output", 1);
    mtrace();
 
    char * text = ( char * ) malloc (sizeof(char) * 100);
    memset(text,'/0',100);
    memcpy(text,"hello,world!",12);
 
    printf("%s/n",text);
    return 0;
}

可以看出,只需要在你的程序中插入三行代码,就行。

第一句,#include <mcheck.h>,包含头文件

第二句,setenv("MALLOC_TRACE", "output", 1);output表示输出的中间文件

第三句,mtrace(),调用mtrace.

 

    将这个文件编译,注意,编译的时候一地要加上gcc的-g选项。

    $   gcc  -g -o mtrace_test mtrace_test.c

    //接着执行可执行文件,然后你会发现当前目录下多了一个output的文件。

    $  ./mtrace_test   //这个必须执行一次,要不然会打印 memrry not leak. 

    $   mtrace mtrace_test output

 

这时会打印出一串信息

- 0x000000000129a010 Free 3 was never alloc'd 0x7f62844d89ba
- 0x000000000129a100 Free 4 was never alloc'd 0x7f6284583a1d
- 0x000000000129a120 Free 5 was never alloc'd 0x7f62845d20ec
 
Memory not freed:
-----------------
           Address     Size     Caller
0x000000000129a5a0     0x64  at /home/dianping/peter/mtrace/mtrace_test.c:12

 

其它别的直接忽略,注意那句要命的 Memory not freed,caller表示那段代码对应的malloc操作没有释放。顺便说一句,如果你编译的时候没有使用-g的选项,那么Caller这个地方就不会出现代码的信息,而是一串二进制的地址信息。 另外还有两个工具据说也不错dmalloc和memwatch.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值