用mtrace检查内存泄露
来源:互联网 发布:tensorflow 二范数 编辑:程序博客网 时间:2024/04/19 12:14
它实际上是通过一对函数来检测一段代码是否存在内存泄漏:
mtrace()与muntrace()。
它们的原型如下:
void mtrace(void);
void muntrace(void);
头文件为:mcheck.h
用法:
1. 首先确定需要检测那一段代码
2. 然后再在这段代码的前面调用mtrace(),在这段代码之后调用muntrace()。
3. 设置环境变量:MALLOC_TRACE,可以在程序编译好后通过命令:
export MALLOC_TRACE=./log //其中log是用来存放内存泄漏信息的日志文件名。
也可以在调用mtrace()之前调用函数设置环境变量:setenv("MALLOC_TRACE", "log", 1);
4. 编译并运行程序,这样内存泄漏信息就会写到log文件中。
5. 查看log文件,如:cat log
注意: 一般情况下不要调用muntrace, 而让程序自然结束. 因为可能有些释放内存代码要到muntrace之后才运行.
实例:
#include <stdio.h>
#include <error.h>
#include <mcheck.h>
int main(void)
{
setenv("MALLOC_TRACE", "log", 1); //设置环境变量MALLOC_TRACE
mtrace(); //在需要检测的代码段之前调用mtrace函数
char *str1 = (char*)malloc(10);
char *str2 = (char*)malloc(10);
if((NULL == str1) || (NULL == str2))
{
perror("can't allocate memory");
}
muntrace(); //在需要检测的代码段之后调用muntrace函数
return 0;
}
将上面的程序编译运行后会在当前目录下产生一个记录=内存泄漏的文件log,其内容如下:
(“+”表示申请的内存,“-”表示释放的内存)
= Start
@ ./test:[0x8048534] + 0x9ed1418 0xa
@ ./test:[0x8048542] + 0x9ed1428 0xa
= End
上面的信息表示:程序分配了两次内存,起内存地址分别是0x9ed1418和0x9ed1428;但并未释放,于是这段程序就存在内存泄漏。
现在我们在示例程序中加上一句:free(str1); 再编译运行后查看log如下:
= Start
@ ./test:[0x8048564] + 0x91ab418 0xa
@ ./test:[0x8048572] + 0x91ab428 0xa
@ ./test:[0x804859c] - 0x91ab418
= End
上面的信息表示:程序申请了两块内存0x91ab418和0x91ab428,但只释放了内存0x91ab418 。故也存在内存泄漏。
当然如果加上free(str1); 与free(str2);则log内容如下:
= Start
@ ./test:[0x8048564] + 0x809b418 0xa
@ ./test:[0x8048572] + 0x809b428 0xa
@ ./test:[0x804859c] - 0x809b418
@ ./test:[0x80485a4] - 0x809b428
= End
这表示申请的内存都释放掉了,故不存在内存泄漏。
通过命令:mtrace log文件 可以解析内存泄露日志
- 用mtrace检查内存泄露
- mtrace内存泄露检查
- linux c 内存泄露检查 mtrace() 笔记
- 用mtrace检查内存泄漏
- 用mtrace检查内存泄漏
- linux下检查内存泄露的工具--mtrace
- linux下检查内存泄露的工具 mtrace
- linux下检查内存泄露的工具--mtrace
- 在linux下使用mtrace工具检查内存泄露
- linux下检查内存泄露的工具--mtrace
- mtrace检查内存泄漏
- mtrace检查内存泄漏
- mtrace检查内存泄漏
- mtrace监测程序内存泄露
- linux 内存泄露检测 mtrace
- 利用mtrace检查内存泄漏
- 使用mtrace检查内存溢出
- 利用mtrace检查内存泄漏
- asp.net开源论坛大列表
- 最名不符实的关键字----static
- android scroll view infinite scroll
- flex chart 去水印 flex data visualization trial 亲自用过,很管用
- Xapian ( Python ) 之 TermGenerator 的简单理解和使用示例
- 用mtrace检查内存泄露
- CString strExt=filename.Right(filename.GetLength()-filename.ReverseFind('.')-1);
- EditText与TextView和BUtton结合使用
- /proc 文件系统
- hdu 2012 洗牌问题
- 企业应用层面知识管理咨询方法
- 一个ERP咨询顾问的九年经验总结
- 开始
- javascript(js)中的 substring和substr方法