在Linux下检查内存泄露

1.什么是内存泄露?

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


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

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

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

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

4.如何检测内存泄露?

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

源文件如下:
在Linux下检查内存泄露
通过分析源程序可以看出,在greeting函数中,当程序向操作系统申请内存后,未对其进行释放操作后,就直接返回主函数,而且主函数不断地调用greeting函数,导致内存一直在泄露中
  • 使用ps命令进行分析
          在一个终端中运行程序:
在Linux下检查内存泄露
在Linux下检查内存泄露
在另一个终端中查看内存状态:
程序运行前内存状态:
在Linux下检查内存泄露
每隔一段时间检查一次内存状态:
在Linux下检查内存泄露
通过分析,我们可以看到,program1程序占用的内存越来越大

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

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

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

运行程序:

在Linux下检查内存泄露

在Linux下检查内存泄露

log文件分析:

在Linux下检查内存泄露

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

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

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

在Linux下检查内存泄露

使用valgrind 命令并运行程序:

在Linux下检查内存泄露

查看目录文件:

在Linux下检查内存泄露

日志中提示有内存块丢失