当前位置: 首页 > 图文教程 > 操作系统 > Unix/Linux > Linux下用Mtrace来检查程序内存溢出

Unix/Linux
linux 操作技巧收集_
linux下如何读取使用iso 镜像文件的方法
Linux平台下文件的压缩与解压参数说明
Linux下常用压缩格式的压缩与解压方法
Linux JDK,TOMCAT安装及环境设置
Linux sleep命令使用参数
Linux cat命令参数
nfs 配置的简单例子
linux kill 关闭进程命令
linux ultrasphinx Anonymous modules have no name to be referenced by
Linux oracle 9i图文安装方法一
Linux oracle 9i图文安装教程二
Linux oracle 9i图文安装教程三
Linux oracle 9i图文安装教程四
Linux oracle 9i图文安装教程五
Linux oracle 9i图文安装教程六 完结篇
linux AS3 oracle9i 安装指南
Linux 下 (RedHat 9.0) JDK,Tomcat,MySQL的安装
RedHat 9.0下Apache+PHP+MySQL服务器安装配置
Linux 下用 Python 连接 MSSql Server 2008

Unix/Linux 中的 Linux下用Mtrace来检查程序内存溢出


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 101 ::
收藏到网摘: n/a

对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。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.logMemory not freed:-----------------Address Size Caller0x08049860 0x14 at /usr/src/build/53700-i386/BUILD/glibc-2.2.4/csu/init.c:0