最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

造成内存泄露的原因

IT圈 admin 29浏览 0评论

2024年4月5日发(作者:伦锐精)

造成内存泄露的原因

内存泄漏一般是指程序中己动态分配的堆内存由于某种原因程序

未释放或无法释放,造成系统内存的浪费。下面店铺给大家分析造成

内存泄露的原因。

造成内存泄露的原因

严格意义上的内存泄露的原因只有一种:没有释放向系统申请的

内存,因为不申请内存,就谈不上什么泄露,搞清楚内存泄露的原因,

应当从汇编语言的角度考虑问题。 当然没有释放内存的原因是多种的:

有可能是你自己代码写的不好,忘记了释放自己代码里申请的内存,

也有可能是你使用了一个写的不好的库,库本身有问题,这里说的库

不仅仅是第三方库,甚至于各种语言的运行时库也有可能出现(再高的

人都免不了出BUG),还甚至于操作系统的库,因为操作系统的BUG

也多的很(当然系统一般情况不会出现这些低级的错误)。 死循环不能

说是内存泄露,概念上应称为死锁,死锁的确是有可能会导致内存无

限量增长,但其与内存泄露有本质区别,尽管有时候它们导致的结果

在内存层面是相同的。

泄漏的分类

以发生的方式来分类,内存泄漏可以分为4类:

(1). 常发性内存泄漏。 发生内存泄漏的代码会被多次执行到,每

次被执行的时候都会导致一块内存泄漏。

(2). 偶发性内存泄漏。 发生内存泄漏的代码只有在某些特定环境

或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,

偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内

存泄漏至关重要。

(3). 一次性内存泄漏。 发生内存泄漏的代码只会被执行一次,或

者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,

在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以

内存泄漏只会发生一次。

(4). 隐式内存泄漏。 程序在运行过程中不停的分配内存,但是

直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因

为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要

运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系

统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

编辑本段危害 从用户使用程序的角度来看,内存泄漏本身不

会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。

真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。

从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,

而隐式内存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄

漏它更难被检测到。

内存泄漏的表现

内存泄漏或者是说,资源耗尽后,系统会表现出什么现象哪?

cpu资源耗尽:估计是机器没有反应了,键盘,鼠标,以及网络

等等。这个在windows上经常看见,特别是中了毒。

进程id耗尽:没法创建新的进程了,串口或者telnet都没法创建

了。

硬盘耗尽: 机器要死了,交换内存没法用,日志也没法用了,死

是很正常的。

内存泄漏或者内存耗尽:新的连接无法创建,free的内存比较少。

发生内存泄漏的程序很多,但是要想产生一定的后果,就需要这个进

程是无限循环的,是个服务进程。当然,内核也是无限循环的,所以,

如果内核发生了内存泄漏,情况就更加不妙。内存泄漏是一种很难定

位和跟踪的错误,目前还没看到有什么好用的工具(当然,用户空间有

一些工具,有静态分析的,也会动态分析的,但是找内核的内存泄漏,

没有好的开源工具)

内存泄漏和对象的引用计数有很大的关系,再加上c/c++都没有

自动的垃圾回收机制,如果没有手动释放内存,问题就会出现。如果

要避免这个问题,还是要从代码上入手,良好的编码习惯和规范,是

避免错误的不二法门。

一般我们常说的内存泄漏是指堆内存的泄漏。

堆内存是指程序从堆中分配的,大小任意的(内存块的大小可以在

程序运行期决定),使用完后必须显示释放的内存。

应用程序一般使用malloc,realloc,new等函数从堆中分配到一

块内存,使用完后,程序必须负责相应的调用free或delete释放该内

存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。

内存泄露的危害

从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,

作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内

存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,

一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内存泄漏

危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测

到。

检查内存的工具

oc-Linux和Solaris下对C和C++程序的简单的使用内

存泄漏和malloc调试库。

c-Debug Malloc Library.

ic Fence-Linux分发版中由Bruce Perens编写的malloc()

调试库。

-Linux下检测内存泄漏的程序。

acer-Linux、Solaris和HP-UX下跟踪和分析C++程序

中的内存泄漏。

CH-由Johan Lindh编写,是一个开放源代码C语言

内存错误检测工具,主要是通过gcc的precessor来进行。

nd-Debugging and profiling Linux programs, aiming

at programs written in C and C++.

grind-A visualization tool for the profiling data

generated by Cachegrind and Calltree.

Rational PurifyPlus-帮助开发人员查明C/C++、托

管.NET、Java和VB6代码中的性能和可靠性错误。PurifyPlus 将内存

错误和泄漏检测、应用程序性能描述、代码覆盖分析等功能组合在一

个单一、完整的工具包中。

ftInsure++-针对C/C++应用的运行时错误自动检测工

具,它能够自动监测C/C++程序,发现其中存在着的内存破坏、内存

泄漏、指针错误和I/O等错误。并通过使用一系列独特的技术(SCI技

术和变异测试等),彻底的检查和测试我们的代码,精确定位错误的准

确位置并给出详细的诊断信息。能作为MicrosoftVisual C++的一个

插件运行。

are DevPartner for Visual C++ BoundsChecker

Suite-为C++开发者设计的运行错误检测和调试工具软件。作为

Microsoft Visual Studio和C++ 6.0的一个插件运行。

ic Software GlowCode-包括内存泄漏检查,code

profiler,函数调用跟踪等功能。给C++和.Net开发者提供完整的错

误诊断,和运行时性能分析工具包。

2024年4月5日发(作者:伦锐精)

造成内存泄露的原因

内存泄漏一般是指程序中己动态分配的堆内存由于某种原因程序

未释放或无法释放,造成系统内存的浪费。下面店铺给大家分析造成

内存泄露的原因。

造成内存泄露的原因

严格意义上的内存泄露的原因只有一种:没有释放向系统申请的

内存,因为不申请内存,就谈不上什么泄露,搞清楚内存泄露的原因,

应当从汇编语言的角度考虑问题。 当然没有释放内存的原因是多种的:

有可能是你自己代码写的不好,忘记了释放自己代码里申请的内存,

也有可能是你使用了一个写的不好的库,库本身有问题,这里说的库

不仅仅是第三方库,甚至于各种语言的运行时库也有可能出现(再高的

人都免不了出BUG),还甚至于操作系统的库,因为操作系统的BUG

也多的很(当然系统一般情况不会出现这些低级的错误)。 死循环不能

说是内存泄露,概念上应称为死锁,死锁的确是有可能会导致内存无

限量增长,但其与内存泄露有本质区别,尽管有时候它们导致的结果

在内存层面是相同的。

泄漏的分类

以发生的方式来分类,内存泄漏可以分为4类:

(1). 常发性内存泄漏。 发生内存泄漏的代码会被多次执行到,每

次被执行的时候都会导致一块内存泄漏。

(2). 偶发性内存泄漏。 发生内存泄漏的代码只有在某些特定环境

或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,

偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内

存泄漏至关重要。

(3). 一次性内存泄漏。 发生内存泄漏的代码只会被执行一次,或

者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,

在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以

内存泄漏只会发生一次。

(4). 隐式内存泄漏。 程序在运行过程中不停的分配内存,但是

直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因

为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要

运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系

统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

编辑本段危害 从用户使用程序的角度来看,内存泄漏本身不

会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。

真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。

从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,

而隐式内存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄

漏它更难被检测到。

内存泄漏的表现

内存泄漏或者是说,资源耗尽后,系统会表现出什么现象哪?

cpu资源耗尽:估计是机器没有反应了,键盘,鼠标,以及网络

等等。这个在windows上经常看见,特别是中了毒。

进程id耗尽:没法创建新的进程了,串口或者telnet都没法创建

了。

硬盘耗尽: 机器要死了,交换内存没法用,日志也没法用了,死

是很正常的。

内存泄漏或者内存耗尽:新的连接无法创建,free的内存比较少。

发生内存泄漏的程序很多,但是要想产生一定的后果,就需要这个进

程是无限循环的,是个服务进程。当然,内核也是无限循环的,所以,

如果内核发生了内存泄漏,情况就更加不妙。内存泄漏是一种很难定

位和跟踪的错误,目前还没看到有什么好用的工具(当然,用户空间有

一些工具,有静态分析的,也会动态分析的,但是找内核的内存泄漏,

没有好的开源工具)

内存泄漏和对象的引用计数有很大的关系,再加上c/c++都没有

自动的垃圾回收机制,如果没有手动释放内存,问题就会出现。如果

要避免这个问题,还是要从代码上入手,良好的编码习惯和规范,是

避免错误的不二法门。

一般我们常说的内存泄漏是指堆内存的泄漏。

堆内存是指程序从堆中分配的,大小任意的(内存块的大小可以在

程序运行期决定),使用完后必须显示释放的内存。

应用程序一般使用malloc,realloc,new等函数从堆中分配到一

块内存,使用完后,程序必须负责相应的调用free或delete释放该内

存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。

内存泄露的危害

从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,

作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内

存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,

一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内存泄漏

危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测

到。

检查内存的工具

oc-Linux和Solaris下对C和C++程序的简单的使用内

存泄漏和malloc调试库。

c-Debug Malloc Library.

ic Fence-Linux分发版中由Bruce Perens编写的malloc()

调试库。

-Linux下检测内存泄漏的程序。

acer-Linux、Solaris和HP-UX下跟踪和分析C++程序

中的内存泄漏。

CH-由Johan Lindh编写,是一个开放源代码C语言

内存错误检测工具,主要是通过gcc的precessor来进行。

nd-Debugging and profiling Linux programs, aiming

at programs written in C and C++.

grind-A visualization tool for the profiling data

generated by Cachegrind and Calltree.

Rational PurifyPlus-帮助开发人员查明C/C++、托

管.NET、Java和VB6代码中的性能和可靠性错误。PurifyPlus 将内存

错误和泄漏检测、应用程序性能描述、代码覆盖分析等功能组合在一

个单一、完整的工具包中。

ftInsure++-针对C/C++应用的运行时错误自动检测工

具,它能够自动监测C/C++程序,发现其中存在着的内存破坏、内存

泄漏、指针错误和I/O等错误。并通过使用一系列独特的技术(SCI技

术和变异测试等),彻底的检查和测试我们的代码,精确定位错误的准

确位置并给出详细的诊断信息。能作为MicrosoftVisual C++的一个

插件运行。

are DevPartner for Visual C++ BoundsChecker

Suite-为C++开发者设计的运行错误检测和调试工具软件。作为

Microsoft Visual Studio和C++ 6.0的一个插件运行。

ic Software GlowCode-包括内存泄漏检查,code

profiler,函数调用跟踪等功能。给C++和.Net开发者提供完整的错

误诊断,和运行时性能分析工具包。

发布评论

评论列表 (0)

  1. 暂无评论