简介
- mtrace 是 GUN glibc 库自带的函数接口,用来记录(因为malloc和free是glibc实现的函数)和分析内存使用问题,不需要使用额外的库。
- mtrace 只能用于c语言,因为它只检测malloc calloc,realloc和free等c语言使用接口
使用方法
- 需要包含头文件 mcheck.h
- 只有两个函数 mtrace(),muntrace()
例子:
#include <stdio.h>
#include <stdlib.h>
#include <mcheck.h>
int main(int argc, const char *argv[])
{
mtrace(); //检测起点
int *a = (int *)malloc(10);
muntrace(); //检测终点,检测到程序末尾时可以省略不写这个
return 0;
}
- 然后在环境变量中添加环境变量MALLOC_TRACE指明生成log文件路径
$ export MALLOC_TRACE=test.log
$ gcc test.c -o test -g
$ ./test
- 然后使用 mtrace 工具分析log文件,并输出到stdout
$ mtrace test test.log
原理: 编译好的程序test会寻找环境变量MALLOC_TRACE并把内存泄漏检测情况输出到里面.mtrace(perl写的)只是一个分析日志文件的工具 输出是这样的:
Memory not freed:
-----------------
Address Size Caller
0x08a99378 0xa at /home/hit9/c/test.c:7
注意项
- 代码编译需要加上 -g, 不然无法定位代码
- mtrace 工具没有平台限制,可以使用linux上的mtrace工具来查看嵌入式设备上生成的log。