Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3785656
  • 博文数量: 880
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 6155
  • 用 户 组: 普通用户
  • 注册时间: 2016-11-11 09:12
个人简介

To be a better coder

文章分类

全部博文(880)

文章存档

2022年(5)

2021年(60)

2020年(175)

2019年(207)

2018年(210)

2017年(142)

2016年(81)

分类: LINUX

2017-12-29 15:08:00

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

 

下面是它的用法

[cpp] view plain copy
  1. #include   
  2. #include   
  3. #include   
  4.    
  5. #include   
  6.    
  7.    
  8. int main(){  
  9.     setenv("MALLOC_TRACE""output", 1);  
  10.     mtrace();  
  11.    
  12.     char * text = ( char * ) malloc (sizeof(char) * 100);  
  13.     memset(text,'/0',100);  
  14.     memcpy(text,"hello,world!",12);  
  15.    
  16.     printf("%s/n",text);  
  17.     return 0;  
  18. }  

 

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

第一句,#include ,包含头文件

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

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

 

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

gcc mtrace_test.c -g -o mtrace_test

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

这个文件自然不是文本文件,所以需要工具来查看。

 

$ 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,不过我没用过,以后用到了在写下使用方法吧

阅读(10631) | 评论(0) | 转发(1) |
0

上一篇:虚拟化嵌套

下一篇:ping端口

给主人留下些什么吧!~~