linux 定位 踩内存_【内存泄漏】方法二:利用linux的mtrace命令定位内存泄露(Memory Leak)...

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

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

下面, 我们来看看程序:

#include

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, 所以能看到泄露还是不泄露。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值