- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
有关内存泄漏的知识
默认分类 2008-02-17 00:32:34 阅读5 评论0 ??字号:大中小?订阅
有关内存泄漏的知识
??????? 最近在看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.内存泄漏的检测
??????? 内存泄漏检测工具介绍: /thread-87138-1-1.html,只是列出了各个工具,具体实践没有。
????
文档评论(0)