51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 2077|回复: 7
打印 上一主题 下一主题

[原创] 扫盲——内存泄漏的有关知识

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2007-8-20 21:02:33 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
扫盲——内存泄漏的有关知识

有关内存泄漏的知识
最近在看LR,对于内存泄漏的知识有点模糊,查找的有关资料,跟大家分享,本文只是介绍了内存泄漏的概念,例子,分类,表现,和检测方法,抛砖引玉,希望大侠们能分享自己检测出的内存泄漏实例
1.概念
简单的说就是你申请了一块内存空间,使用完毕后没有释放掉。它的一般表现方式是程序运行时间越长,占用内存越多,最终用尽全部内存,整个系统崩溃。由程序申请的一块内存,且没有任何一个指针指向它,那么这块内存就泄露了。
2.泄漏的例子
举几个例子   
  void   fun0()   
  {   
      char   *p=new   char[100];   
  }   
  执行完上面的函数就发生了泄露   
  指针p是局部变量,函数执行完后,指针p被销毁,造成   new   char[100]的内存没有指针指向它   
  ,也就无法再使用,造成内存泄漏。  
  void   fun1()   
  {   
      char   *p=new   char[100];   
      p=new   char[100];   
  }   
  这也泄露了   
   
  void   fun2()   
  {   
      new   char[100];   
  }   
  这东西肯定泄露完了   
   
  void   fun3(char   *a)   
  {   
      char   *p=new   char[100];   
      char   *b=p;   
      p=a;   
      a=b;   
  }   
  可能有泄露,赶紧去加内存条。
3.泄漏的分类
以发生的方式来分类,内存泄漏可以分为4类:

1. 常发性内存泄漏。发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。
2. 偶发性内存泄漏。发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。
3. 一次性内存泄漏。发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以内存泄漏只会发生一次。
4. 隐式内存泄漏。程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测到。
4.内存泄漏的表现
内存泄漏或者是说,资源耗尽后,系统会表现出什么现象哪?
cpu资源耗尽:估计是机器没有反应了,键盘,鼠标,以及网络等等。这个在windows上经常看见,特别是中了毒。
进程id耗尽:没法创建新的进程了,串口或者telnet都没法创建了。
硬盘耗尽: 机器要死了,交换内存没法用,日志也没法用了,死是很正常的。
内存泄漏或者内存耗尽:新的连接无法创建,free的内存比较少。发生内存泄漏的程序很多,但是要想产生一定的后果,就需要这个进程是无限循环的,是个服务进程。当然,内核也是无限循环的,所以,如果内核发生了内存泄漏,情况就更加不妙。内存泄漏是一种很难定位和跟踪的错误,目前还没看到有什么好用的工具(当然,用户空间有一些工具,有静态分析的,也会动态分析的,但是找内核的内存泄漏,没有好的开源工具)
内存泄漏和对象的引用计数有很大的关系,再加上c/c++都没有自动的垃圾回收机制,如果没有手动释放内存,问题就会出现。如果要避免这个问题,还是要从代码上入手,良好的编码习惯和规范,是避免错误的不二法门。
5.内存泄漏的检测
内存泄漏检测工具介绍: http://bbs.51testing.com/thread-87138-1-1.html,只是列出了各个工具,具体实践没有
另外网上还有很多针对java和c++等的内存泄漏的文章
Java内存泄漏:http://www.blogjava.net/galaxyp/archive/2006/04/28/43724.html
VC6.0内存泄漏检测:http://leoman95.spaces.live.com/ ... e8fa434b1!131.entry
LR中:如果Process\Private Bytes计数器和Process\Working Set计数器的值持续升高,同时Memory\Available bytes计数器的值却持续降低的话,说明很有可能是存在内存泄漏
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2007-8-21 00:31:11 | 只看该作者
顶  对内存泄漏有了一点初步的认识 多谢^_^
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2007-8-21 09:15:07 | 只看该作者
同一个板块的帖子  没过几天转来转去 有意思吗?

原帖应该标明出处:http://bbs.51testing.com/thread-87157-1-4.html

[ 本帖最后由 shanxi 于 2007-8-21 10:47 编辑 ]
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2007-8-21 09:51:42 | 只看该作者
对内存泄露有了进一步的认识,谢谢lz拉

想请教一下,用lr测试性能时,如果吞吐量曲线没有显著的变化,在一定时期内保持稳定,而内存值曲线却始终持续增加,是否可以说明是内存泄露的表现呢?

还有能否再介绍下内存泄露和资源泄露的区别呢?
回复 支持 反对

使用道具 举报

该用户从未签到

5#
发表于 2007-8-21 10:10:39 | 只看该作者
谢谢,不是很懂,大致了解了些。谢谢
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2007-8-21 12:08:47 | 只看该作者
UP学习
回复 支持 反对

使用道具 举报

该用户从未签到

7#
发表于 2007-8-21 16:55:28 | 只看该作者

回复 #4 hadywei 的帖子

说的有道理.
回复 支持 反对

使用道具 举报

该用户从未签到

8#
发表于 2007-8-21 23:05:16 | 只看该作者
不错不错,收藏了
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-24 17:11 , Processed in 0.076125 second(s), 28 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表