【内存泄漏】方法二:利用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, 所以能看到泄露还是不泄露。

posted @   _小百  阅读(1721)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示