设为首页收藏本站language→→ 语言切换

鸿鹄论坛

 找回密码
 论坛注册

QQ登录

先注册再绑定QQ

查看: 2081|回复: 3
收起左侧

Linux下用Mtrace来检查程序内存溢出

[复制链接]
发表于 2010-9-19 22:33:39 | 显示全部楼层 |阅读模式
对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。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

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


[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
发表于 2012-1-11 16:50:26 | 显示全部楼层
沙发 2012-1-11 16:50:26 回复 收起回复
回复 支持 反对

使用道具 举报

发表于 2012-1-19 08:05:17 | 显示全部楼层
thanks
板凳 2012-1-19 08:05:17 回复 收起回复
回复 支持 反对

使用道具 举报

发表于 2012-7-30 08:53:56 | 显示全部楼层
地板 2012-7-30 08:53:56 回复 收起回复
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 论坛注册

本版积分规则

QQ|Archiver|手机版|小黑屋|sitemap|鸿鹄论坛 ( 京ICP备14027439号 )  

GMT+8, 2025-1-26 15:40 , Processed in 0.054852 second(s), 11 queries , Redis On.  

  Powered by Discuz!

  © 2001-2025 HH010.COM

快速回复 返回顶部 返回列表