zoukankan      html  css  js  c++  java
  • mtrace分析内存泄漏 Hello

    1. 测试程序

    #include <stdio.h>
    #include <string.h>
    #include <stdlib.h>
    #include <sys/time.h>
    #include <mcheck.h>
    
    static void memory_leak_test()
    {
        char *p = malloc(4 * 1024);
        free(p);
        p = malloc(2 * 1024);
        p = malloc(1 * 1024);
    }
    
    static int check_leak_start(void)
    {
       char log_path[64] = "./log";
       setenv("MALLOC_TRACE", log_path, 1); //设置log保存路径
       mtrace();
    
       return 0;
    }
    
    static int check_leak_end(void)
    {
       char log_path[64] = "./log";
       setenv("MALLOC_TRACE", log_path, 1); //设置log保存路径
       mtrace();
    
       return 0;
    }
    
    void main()
    {
        check_leak_start();
        memory_leak_test();
        check_leak_end();
    }

    实验结果:

    ~/tmp/mtrace_test$ gcc -g mtrace_test.c -o pp
    ~/tmp/mtrace_test$ ./pp
    ~/tmp/mtrace_test$ cat log 
    = Start
    @ ./pp:[0x400678] + 0x1609560 0x1000
    @ ./pp:[0x400688] - 0x1609560
    @ ./pp:[0x400692] + 0x1609560 0x800
    @ ./pp:[0x4006a0] + 0x1609d70 0x400
    ~/tmp/mtrace_test$ 
    ~/tmp/mtrace_test$ addr2line -f -e pp 0x400678
    memory_leak_test
    .../tmp/mtrace_test/mtrace_test.c:10
    ~/tmp/mtrace_test$ 
    ~/tmp/mtrace_test$ addr2line -f -e pp 0x400688
    memory_leak_test
    .../tmp/mtrace_test/mtrace_test.c:12 //应该是11行的,有点错位
    ~/tmp/mtrace_test$
    ~/tmp/mtrace_test$ addr2line -f -e pp 0x400692
    memory_leak_test
    .../tmp/mtrace_test/mtrace_test.c:12
    ~/tmp/mtrace_test$
    ~/tmp/mtrace_test$ addr2line -f -e pp 0x4006a0
    memory_leak_test
    .../tmp/mtrace_test/mtrace_test.c:13

    总结

    只是打印出申请和释放内存的位置。

    参考:https://zhuanlan.zhihu.com/p/83547768

  • 相关阅读:
    可持久化线段树学习笔记
    GDI+学习之路
    tcpdump——分析tcp关闭4次过程
    nasm过程调用
    ios学习:NSURLConnection 和 Json数据解析
    ios学习:文件简单读写
    JSONP原理及其简单封装
    JSP使用JSTL
    JDBC
    Apache无法正常启动的原因
  • 原文地址:https://www.cnblogs.com/hellokitty2/p/15577846.html
Copyright © 2011-2022 走看看