Chinaunix首页 | 论坛 | 博客
  • 博客访问: 10804991
  • 博文数量: 2905
  • 博客积分: 20098
  • 博客等级: 上将
  • 技术积分: 36298
  • 用 户 组: 普通用户
  • 注册时间: 2009-03-23 05:00
文章存档

2012年(1)

2011年(3)

2009年(2901)

分类: LINUX

2009-03-23 11:24:24

1. 在需要内存泄漏检查的代码的开始调用void mtrace(void) (在mcheck.h中? 有声明). mtrace为malloc等函数安装hook, 用于记录内存分配信息.在需要内存泄漏检查的代码的结束调用void muntrace(void).

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

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

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

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

    5. 用mtrace命令解析内存分配Log文件($MALLOC_TRACE)
    (mtrace foo $MALLOC_TRACE, where foo is the executible name)
 
    如果有内存泄漏, mtrace会输出分配泄漏
    内存的代码位置,以及分配数量.

    附加说明

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

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

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

    For C++ Leak:

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

    很奇怪,redhat 9 居然不带mtrace perl脚本,只好下载gcc源码编译了
    wget --passive-ftp ... -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

    1 #include
    2
    3 int main()
    4 {
    5 mtrace();
    6 malloc(10);
    7 malloc(16);
    8 return 0;
    9 }

    $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
    可以看到,会显示未释放动态空间的代码具体位置。
阅读(1326) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~