关于Linux操作系统下内存泄漏的检查方法

文章出处:http://www.enet.com.cn/article/2008/0320/A20080320191430.shtml

 

1.  在需要内存泄漏检查的代码的开始调用void mtrace(void)。

    mtrace为malloc等函数安装hook,用于记录内存分配信息。在需要内存泄漏检查的代码的结束调用void muntrace(void)。

    注意:一般情况下不要调用muntrace,而让程序自然结束因为有可能释放内存代码要到muntrace之后才运行

2.  用debug模式编译被检查代码(-g 或 -gdb)

3.  设置环境变量MALLOC_TRACE为一文件名,这一文件将存有内存分配信息。

4.  运行被检查程序,直至结束或muntrace被调用。

5.  用mtrace命令解析内存分配log文件($MALLOC_TRACE)。

     ( mtrace foo $MALLOC_TRACE, where foo is the executable name )

    如果有内存泄漏,mtrace会输出分配泄漏内存的代码位置,以及分配数量。

附加说明:

1.  可以将mtrace,muntrace放入信号处理函数(USR1, USR2),以动态地进行内存泄漏检查控制

2.  mtrace是个perl代码,如果你对符号地址与代码文本的转换感兴趣,可以读一下;

3.  again,尽量不要用muntrace()

 

For C++ Leak:

检查内存泄漏的方法除glibc提供外,还可以试试一些专用的程序。

很奇怪,redhat9居然不带mtarce perl脚本,只好下载gcc源码编译了

wget --passive-ftp ftp://rpmfind.net/linux/redhat/9 ... -2.3.2-11.9.src.rpm

rpm -ivh glibc*.src.rpm
cd /usr/src/redhat/SPECS/
rpmbuild -ba glibc-9.spec
cd /var/tmp/glibc-2.3.2-root/usr/bin/
cp mtrace /usr/bin/

 

调试方法如下:

vi  a.c

 

$gcc -g a.c  #记得编译带-g调试选项

$export MALLOC_TRACE=a.log

 

$./a.out

$unset MALLOC_TRACE  #记得执行完后unset变量,否则运行其他命令可能覆盖log

$mtrace  a.out  a.log

Memory not freed:

———————————————————————————————————————

Address Size Caller

0x09b08378   0xa    at   /XXX/a.c:6

0x09b08388   0x10  at   /XXX/a.c:7

 

可以看到,会显示未释放动态空间的代码的具体位置。

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值