1.什么是内存泄露?
内存泄露指的是应用程序在分配某段内存后,由于设计错误,失去了对该段内存的控制,因而造成了内存的浪费。
2.造成内存泄露的原因是什么?
一般情况下造成内存泄露的主要原因是,由于程序设计的不合理,未对动态申请的堆空间进行回收,或者只在程序的部分出口对申请的内存空间进行回受,从而导致被某个程序弃用却不能被其他程序使用的内存越来越多。
3.内存泄露带来的危害:
内存泄露会减少可用内存的数量从而降低计算机的性能。而且当所消耗的内存达到系统的上限时,程序自己会崩溃,严重者甚至会导致系统挂起或崩溃。
4.如何检测内存泄露?
a.使用相关命令,如ps,top等
源文件如下:
通过分析源程序可以看出,在greeting函数中,当程序向操作系统申请内存后,未对其进行释放操作后,就直接返回主函数,而且主函数不断地调用greeting函数,导致内存一直在泄露中
- 使用ps命令进行分析
在一个终端中运行程序:
在另一个终端中查看内存状态:程序运行前内存状态:
每隔一段时间检查一次内存状态:通过分析,我们可以看到,program1程序占用的内存越来越大
- 使用top命令进行分析
同样地在一个终端中运行程序,然后在另一个终端中观察状态:通过分析,我们可以看到,program1程序占用的内存越来越大
b.进行静态分析,如使用工具mtrace
修改源程序: 添加头文件,并且用mtrace()和muntrace()两条语句将要检测内存泄露的代码块包含起来编译程序并用该环境变量来定义一个文件log用于输出:运行程序:
log文件分析:
日志中一连串的"+"号表示程序一直在申请内存空间,(若有“-”号,表示程序在释放空间)c.进行动态分析,如如使用valgrind或者memwatch等工具等
将第二步修改的代码注释掉:
使用valgrind 命令并运行程序:
查看目录文件:
日志中提示有内存块丢失