· [Java论坛][安全论坛][数据库论坛][操作系统论坛]
· [专题] IBM Rational高峰论坛 Windows 7十大功能
· [专题] 史上就危险7月 微软 BizSpark 计划介绍
· [IT技术周刊][IT资源下载专区][病毒求助专区]
· [热点] 我也能做CTO_赛迪连载 赛迪七夕特别行动
· [热点] Chrome 4.0采用V8引擎 Java开发编程规范

Linux系统下使用mtrace进行内存状况监测

发布时间:2008.03.06 06:13     来源:赛迪网    作者:korn

对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。Debug起来也是比较累人。其实Linux系统下有一个使用的工具可以帮忙来调试的,这就是Mtrace。Mtrace主要能够检测一些内存分配和泄漏的失败等。下面我们来学习一下它的用法。

使用Mtrace来调试程序有4个基本的步骤,需要用到GNU C 函数库里面的一些辅助的函数功能。

1.在需要跟踪的程序中需要包含头文件,而且在main()函数的最开始包含一个函数调用:mtrace()。由于在main函数的最开头调用了mtrace(),所以该进程后面的一切分配和释放内存的操作都可以由mtrace来跟踪和分析。

2.定义一个环境变量,用来指示一个文件。该文件用来输出log信息。如下的例子:

$export MALLOC_TRACE=mymemory.log

3.正常运行程序。此时程序中的关于内存分配和释放的操作都可以记录下来。

4.然后用mtrace使用工具来分析log文件。例如:

$mtrace testmem $MALLOC_TRACE

要注意的是,在很多嵌入式的环境中,并不提供export命令,也没有记录环境变量的文件。这时候难道就没有办法了么?呵呵,也许,唯一的办法就是把环境变量加到应用程序中。在Glibc库中有putenv函数,就是写入环境变量的。具体的请自己查手册。

int putenv (char *string) [Function]

设置好环境变量后。又有一个问题了:如果程序是自运行的,即没有终止的时候,那想在特定的地方,分析内存情况,怎么办呢?

呵呵,还是看Glibc!,调用muntrace函数,log文件就生成了。这时用mtrace命令分析log文件就可以啦。

下面是具体一个例子,大家可以看一下。

[hwang@langchao test]$ cat testmtrace.c
#include <>
#include
#include
int main()
{
char *hello;
mtrace();
hello = (char*) malloc(20);
sprintf(hello,"
hello world!");
return 1;
}
[hwang@langchao test]$export MALLOC_TRACE=mytrace.log
[hwang@langchao test]$ gcc testmtrace.c -o testmtrace
[hwang@langchao test]$./testmtrace
[hwang@langchao test]$ mtrace testmtrace mytrace.log
Memory not freed:
-----------------
Address Size Caller
0x08049860 0x14 at /usr/src/build/53700-i386/BUILD/glibc-2.2.4/csu/init.c:0

(责任编辑:云子)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· OpenSUSE系统下使用SAMBA建立文件服务器 (03-05) · Ubuntu Linux Desktop CD硬盘安装的技巧 (03-05)
· 实用技巧:让三个主流系统共存常用方法 (03-05) · Windows系统下如何访问Linux分区的文件 (03-05)
· IBM免费办公软件将支持UOF、ODF及OOXML (03-05) · 安全宝典:保障Linux系统安全的九大技巧 (03-05)
· 详细解析:在CentOS下安装配置VNC的过程 (03-04) · Ubuntu Linux系统下常见问题的解决方法 (03-04)
· Linux操作系统邮件服务器的搭建过程解析 (03-04) · Linux系统下蓝牙立体声配置A2DP profile (03-04)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
资讯 通信 IT产品 IT技术 信息化
专题:扭亏为盈 联想09年Q2翻番
·专题:Tech·Ed 2009微..
·直播:2009互联网大会..
·迅雷搜狐"互搏" 谁动了..
专题:诺基亚危局已现 或重蹈摩托覆辙
·六股势力角逐4G标准 中..
·专题:联通iPhone并不贵..
·专题:排排坐开商店 三..
商务演示需求分析 多媒体会议室必备投影
·VMware在京隆重举行2009..
·专题:笔记本频道10月热..
·专题:学生机市场 惠普 ..
专题:Tech.Ed 2009微软技术大会
·专题:2009 SYBASE 亚太..
·专题:微软新一代桌面操..
·专题:2009年第3届CSDN..