linux下检查内存泄露的工具--mtrace
2016-01-12 17:53
861 查看
最令linux程序员头疼的莫过于内存泄露了,即使你是在优秀的程序员,你也不能保证所以的malloc操作都有对应的free,那必要的工具就是必不可少的了。在一般的linux发行版中,有一个自带的工具可以很方便的替你完成这些事,这个工具就是mtrace。
下面是它的用法
[cpp] view
plaincopy
#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 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,不过我没用过,以后用到了在写下使用方法吧
下面是它的用法
[cpp] view
plaincopy
#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 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,不过我没用过,以后用到了在写下使用方法吧
相关文章推荐
- linux设置开机启动服务的集中方法
- 给结构体指针分配内存后依然出现段错误的解决
- Linux下txt文件与mysql数据库导入导出
- linux下搭建LAMP
- 为Linux 保留一部分物理内存
- Linux 内核调优
- PostgreSQL9.5在CentOS 7 x86_64下的安装
- Linux设备驱动开发 - LCD设备驱动分析
- CentOS 7 的初始化
- linux mutex lock: pthread_mutex_t mutex_lock
- Centos设置yum源
- 一个C程序的编译过程(Linux环境下GCC)
- Linux内核中创建cache节点由函数kmem_cache_create()实现
- linux 磁盘,分区,文件系统,挂载点。
- linux下makefile多文件编译
- logger(二):linux下syslog & syslog-ng 详解
- Linux中正则表达式与文件格式化处理命令(awk/grep/sed)
- CentOS 7部署OpenStack(9)―部署dashboard
- linux PS1环境变量使用
- Linux下软件安装和卸载