在Linux下检查内存泄露

1.什么是内存泄露?

内存泄露指的是应用程序在分配某段内存后,由于设计错误,失去了对该段内存的控制,因而造成了内存的浪费。


2.造成内存泄露的原因是什么?

一般情况下造成内存泄露的主要原因是,由于程序设计的不合理,未对动态申请的堆空间进行回收,或者只在程序的部分出口对申请的内存空间进行回受,从而导致被某个程序弃用却不能被其他程序使用的内存越来越多。

3.内存泄露带来的危害:

内存泄露会减少可用内存的数量从而降低计算机的性能。而且当所消耗的内存达到系统的上限时,程序自己会崩溃,严重者甚至会导致系统挂起或崩溃。

4.如何检测内存泄露?

a.使用相关命令,如ps,top等

源文件如下:

通过分析源程序可以看出,在greeting函数中,当程序向操作系统申请内存后,未对其进行释放操作后,就直接返回主函数,而且主函数不断地调用greeting函数,导致内存一直在泄露中
  • 使用ps命令进行分析
          在一个终端中运行程序:


在另一个终端中查看内存状态:
程序运行前内存状态:

每隔一段时间检查一次内存状态:
通过分析,我们可以看到,program1程序占用的内存越来越大

  • 使用top命令进行分析
同样地在一个终端中运行程序,然后在另一个终端中观察状态:
通过分析,我们可以看到,program1程序占用的内存越来越

b.进行静态分析,如使用工具mtrace

修改源程序: 添加头文件,并且用mtrace()和muntrace()两条语句将要检测内存泄露的代码块包含起来
编译程序并用该环境变量来定义一个文件log用于输出

运行程序:

log文件分析:

日志中一连串的"+"号表示程序一直在申请内存空间,(若有“-”号,表示程序在释放空间)

c.进行动态分析,如如使用valgrind或者memwatch等工具等

将第二步修改的代码注释掉:

使用valgrind 命令并运行程序:


查看目录文件:


日志中提示有内存块丢失

     
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值