zoukankan      html  css  js  c++  java
  • 【内存泄漏】方法二:利用linux的mtrace命令定位内存泄露(Memory Leak)

    借鉴于:https://blog.csdn.net/stpeace/article/details/46642507

    linux小命令:mtrace(memory trace), 它可以用来协助定位内存泄露。 搞开发的, 应该或多或少地听说过mtrace.

            下面, 我们来看看程序:

    #include <stdio.h>

     

    int main()

    {

            setenv("MALLOC_TRACE", "test.log", "1");

            mtrace();

     

            int *p = (int *)malloc(2 * sizeof(int));

     

            return 0;

    }

    编译:gcc -g -DDEBUG test.c   (千万要注意, -g不可漏掉, 否则, 虽然最后能定位到内存泄露, 但却找不到在代码的第几行。由于我代码中没有Debug宏控制, 所以编译时, -DDEBUG是可以省略的, 因此, 直接写成gcc -g mtrace.c -o mtrace即可)

            运行:./mtrace

            定位:mtrace mtrace  test.log

            结果:

     可以看到, 有内存泄露,且正确定位到了代码的行数。

     mtrace函数/命令的原理,记录每一对malloc/free的调用情况, 从这个意义上来讲, mtrace替代了部分我们的眼睛, 紧紧地盯着malloc/free, 所以能看到泄露还是不泄露。

  • 相关阅读:
    python基础——反射
    python基础——模块
    python基础——异常处理、递归
    python基础——生成器与迭代器
    python基础——装饰器
    Python常见面试题
    Socket网络编程
    爬虫解析相关
    爬虫请求相关
    初识爬虫
  • 原文地址:https://www.cnblogs.com/baiduboy/p/13535820.html
Copyright © 2011-2022 走看看