内存溢出和内存泄漏的区别

文章目录

    • 一、什么是内存
    • 二、定义不同
    • 三、产生原因不同
    • 四、处理方式不同
    • 五、影响程度不同
    • 六、检测工具不同

一、什么是内存

内存(Memory)是计算机用于存储和访问数据和指令的设备。它是计算机系统中的一个重要组成部分,用于临时存储和处理数据。内存可以被看作是计算机的”大脑”,用于存储正在执行的程序和数据,以及中间结果和临时变量。

计算机内存由一系列存储单元组成,每个存储单元都有一个少数的地址。这些存储单元可以存储二进制数据,包括程序指令和运行时数据。内存的主要特点是可以读取和写入数据,以及较快的访问速度。

内存分为几个不同的层次。非常快速但最小容量的是处理器内部的寄存器,用于存储指令和数据的中间结果。其次是高速缓存Cache),它是位于处理器和主内存之间的一种存储器,用于加速对常用数据的访问。最后是主内存RAM),它是计算机系统中最大的存储器,用于存储当前正在执行的程序和数据。

内存的容量通常以字节(Byte)为单位进行衡量。常见的内存容量单位有千字节(Kilobyte,KB)、兆字节(Megabyte,MB)、千兆字节(Gigabyte,GB)和万兆字节(Terabyte,TB)等。随着技术的发展,内存容量不断增加,以满足现代计算机处理大规模数据和复杂任务的需求。

需要注意的是,内存是一种临时存储设备,当计算机断电或重新启动时,内存中的数据将被清空。 因此,为了长期保存数据,需要将其存储到永久性存储介质(如硬盘或固态硬盘)中。

二、定义不同

  • 内存溢出Out Of MemoryOOM):程序在申请内存时,没有足够的内存空间供其使用,就会发生内存溢出。

  • 内存泄漏Memory Leak):程序在申请内存后,无法(及时)释放已申请的内存空间,一次内存泄漏可能影响不大,但内存泄漏积累后,会极大影响程序运行,可能导致内存耗尽甚至系统崩溃。

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

  1. 常发性内存泄漏:发生内存泄漏的代码会被多次执行到,每次被执行的时候都会导致一块内存泄漏。

  2. 偶发性内存泄漏:发生内存泄漏的代码只有在某些特定环境或操作过程下才会发生。常发性和偶发性是相对的。对于特定的环境,偶发性的也许就变成了常发性的。所以测试环境和测试方法对检测内存泄漏至关重要。

  3. 一次性内存泄漏:发生内存泄漏的代码只会被执行一次,或者由于算法上的缺陷,导致总会有一块仅且一块内存发生泄漏。比如,在类的构造函数中分配内存,在析构函数中却没有释放该内存,所以内存泄漏只会发生一次。

  4. 隐式内存泄漏:程序在运行过程中不停的分配内存,但是直到结束的时候才释放内存。严格的说这里并没有发生内存泄漏,因为最终程序释放了所有申请的内存。但是对于一个服务器程序,需要运行几天,几周甚至几个月,不及时释放内存也可能导致最终耗尽系统的所有内存。所以,我们称这类内存泄漏为隐式内存泄漏。

从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测到。

三、产生原因不同

  • 内存溢出:内存溢出的产生通常是因为程序申请的内存超出了系统能够提供的范围,比如试图创建一个超大的数组或对象,超过了系统或虚拟机的限制。比如申请了一个integer,但给它存了long才能存下的数,就会造成内存溢出

    举个例子:一个盘子用尽各种方法只能装4个果子,你装了5个,结果掉倒地上不能吃了。这就是溢出!比方说栈,栈满时再做进栈必定产生空间溢出,叫上溢,栈空时再做退栈也产生空间溢出,称为下溢。就是分配的内存不足以放下数据项序列,称为内存溢出。
    再或者:比如总内存大小是100MB,一次程序运行结束有,有10MB 没有释放,当前可用内存还有90MB,程序还可以运行。但是多次运行后,可用内存最终为0, 没有可以内存或内存不足时,程序在下一次运行时,会因为内存不足,而出现内存溢出

    放在实际项目中,引起内存溢出的常见原因有以下几种:

    1. 内存中加载的数据量过于庞大,如一次从数据库取出过多数据;
    2. 集合类中有对对象的引用,使用完后未清空,使得JVM不能回收;
    3. 代码中存在死循环或循环产生过多重复的对象实体;
    4. 使用的第三方软件中的BUG;
    5. 启动参数内存值设定的过小 。


    注⚠️:内存泄露(memory leak)会最终会导致内存溢出(out of memory)!

  • 内存泄漏:内存泄漏通常是由于程序的设计问题导致的,比如忘记释放已经不再使用的内存,或者引用已不需要的对象,使得这部分内存无法被回收。

单例模式中,单例的生命周期和应用程序是一样长的,所以单例程序中如果持有对外部对象的引用的话,那么这个外部对象是不能被回收的,则会导致 内存泄露 的产生。

一些提供close的资源未闭导致 内存泄漏 。数据库连接(dataSource.getConnection() ),网络连接(socket)和 IO流的连接必须在finally中 close,否则不能被回收的。

读取大文件,一次读取的文件大于可用内存,会导致 内存溢出 。可用内存是1G,怎么读取2G的文件呢?建一个100MB的字节数组,读10次。

四、处理方式不同

  • 内存溢出:对于内存溢出的问题,通常需要检查程序是否有不必要的大内存申请,或者优化程序使得内存使用更加高效。

    放在实际项目中,内存溢出的解决方案如下:

    1. 修改 JVM 启动参数,直接增加内存。( -Xms-Xmx 参数一定不要忘记加)

    2. 检查错误日志,查看 “OutOfMemory” 错误前是否有其它异常或错误。

    3. 对代码进行走查和分析,找出可能发生内存溢出的位置。

重点排查以下几点:

  • 检查数据库查询中是否有一次获得全部数据的查询(即全表查询)。 一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。 这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用条件查询和分页的方式查询。

  • 检查代码中是否有死循环或递归调用。

  • 检查是否有大循环重复产生新对象实体。

  • 检查List、MAP等集合对象是否有使用完后,未清除的问题。 List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。

  1. 使用内存查看工具动态查看内存使用情况。Jmap获取内存堆信息/arthas在线分析。
  • 内存泄漏:对于内存泄漏的问题,首先需要定位程序中导致内存泄漏的部分,然后修复这些问题,比如及时释放不再使用的内存,或者取消对不再需要的对象的引用。

五、影响程度不同

  • 内存溢出:内存溢出会导致程序立即崩溃或者抛出错误,影响较大。

  • 内存泄漏:一次小的内存泄漏可能不会立即影响程序运行,但是如果大量内存泄漏累积,最终会导致内存耗尽,影响系统的正常运行。

六、检测工具不同

  • 内存溢出:可以通过一些性能监控工具来预防内存溢出,如JProfiler、MAT等。

  • 内存泄漏:一些内存分析工具可以帮助检测内存泄漏,如Valgrind、LeakCanary等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/73259.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jmeter 线程组 Open Model Thread Group 阶梯式压测、高峰流量压测

简介 Open Model Thread Group 是5.4.1 版本中引入的一个实验性线程组,可以弹性模拟负载测试。例如设置多个线程模式,再根据这些线程模式调整不同的并发数、暂停时间。由于Open Model Thread Group 是一个实验性线程组,可能会存在一些限制和不…

2.9 PE结构:重建导入表结构

脱壳修复是指在进行加壳保护后的二进制程序脱壳操作后,由于加壳操作的不同,有些程序的导入表可能会受到影响,导致脱壳后程序无法正常运行。因此,需要进行修复操作,将脱壳前的导入表覆盖到脱壳后的程序中,以…

【群智能算法改进】一种改进的鹈鹕优化算法 IPOA算法[2]【Matlab代码#58】

文章目录 【获取资源请见文章第5节:资源获取】1. 原始POA算法2. 改进后的IPOA算法2.1 随机对立学习种群初始化2.2 动态权重系数2.3 透镜成像折射方向学习 3. 部分代码展示4. 仿真结果展示5. 资源获取 【获取资源请见文章第5节:资源获取】 1. 原始POA算法…

【JavaScript】在指定dom元素前面创建标签元素

一、基础操作过程 要在指定的DOM元素前面创建标签元素,有以下步骤: 获取指定的DOM元素:使用document.querySelector()或document.getElementById()等方法来获取指定的DOM元素。 const targetElement document.querySelector(#targetElement…

数字展厅有什么优势,一文了解数字展厅建设方案

引言: 在当今数字化风潮的席卷下,企业们正积极寻求创新的方式来吸引和互动他们的客户。数字展厅作为一种新型的虚拟宣传工具,已经开始引起广泛的关注。 一.什么是数字展厅? 数字展厅是一种基于虚拟现实(V…

【前端】在Vue页面中引入其它vue页面 数据传输 相互调用方法等

主页面 home 从页面 headView 需求 在 home.vue 中引用 headView.Vue 方案: home.vue 代码: 只需要在home.vue 想要的地方添加 <headView></headView> <script>//聊天页面 import headView /view/headView.vueexport default {components: {headView},…

淘宝商品销量接口API更新(总销+精准月销API)

不少客户有获取淘宝商品销量的需求&#xff0c;淘宝商品销量接口主要用于以下业务场景。有不齐全的欢迎大家补充。 库存管理&#xff1a;商家可以通过接口获取到实时的销量信息&#xff0c;更好地进行库存管理。供应链计划&#xff1a;商家可以通过接口了解到商品的销售趋势&a…

Unity的UI面板基类

使用这个组件实现淡入淡出 public abstract class BasePanel : MonoBehaviour {//控制面板透明度 用于淡入淡出private CanvasGroup canvasGroup;//淡入淡出速度private float alphaSpeed 10;//隐藏还是显示public bool isShow false;//隐藏完毕后做的事private UnityAction …

rosdep init 错误解决终极方法(药到病除)

参考文章 rosdep init 错误解决终极方法&#xff08;药到病除&#xff09;

图像分割--点、线和边缘检测

图像分割 图像分割是指将图像细分为构成它的子区域或物体本章算法基于灰度值的两个基本性质之一&#xff1a;不连续性和相似性 点、线和边缘检测 就像局部平均平滑一幅图像那样&#xff0c;假设平均处理类似于积分&#xff0c;对于灰度的突变&#xff0c;局部变化可以用微分…

thinkphp6 入门教程合集(更新中)

thinkphp6 入门&#xff08;1&#xff09;--安装、路由规则、多应用模式 thinkphp6 入门&#xff08;1&#xff09;--安装、路由规则、多应用模式_软件工程小施同学的博客-CSDN博客 thinkphp6 入门&#xff08;2&#xff09;--视图、渲染html页面、赋值 thinkphp6 入门&#…

企业电子招标采购系统源码Spring Boot + Mybatis + Redis + Layui + 前后端分离 构建企业电子招采平台之立项流程图

功能模块&#xff1a; 待办消息&#xff0c;招标公告&#xff0c;中标公告&#xff0c;信息发布 描述&#xff1a; 全过程数字化采购管理&#xff0c;打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力&#xff0c;为外部供…

Web安全——穷举爆破下篇(仅供学习)

Web安全 一、常见的端口服务穷举1、hydra 密码穷举工具的使用2、使用 hydra 穷举 ssh 服务3、使用 hydra 穷举 ftp 服务4、使用 hydra 穷举 mysql 服务5、使用 hydra 穷举 smb 服务6、使用 hydra 穷举 http 服务7、使用 hydra 穷举 pop3 服务8、使用 hydra 穷举 rdp 服务9、使用…

Ubuntu18.04更改镜像源(网易,阿里,清华,中科大,浙大)

一&#xff0c;备份原来的源&#xff08;选做&#xff09; sudo cp /etc/apt/sources.list /etc/apt/sources_init.list 二&#xff0c;更换源 sudo gedit /etc/apt/sources.list 删除原来内容改为新的镜像源 1&#xff0c;清华源 deb https://mirrors.tuna.tsinghua.edu…

适用于基于晶圆键合的3D集成应用的高效单晶圆清洗

引言 不同的微电子工艺需要非常干净的表面以防止颗粒污染。其中&#xff0c;晶圆直接键合对颗粒清洁度的要求非常严格。直接晶圆键合包括通过简单地将两种材料的光滑且干净的表面接触来将两种材料连接在一起&#xff08;图1&#xff09;。在室温和压力下&#xff0c;两种材料表…

OMRON G9SP和NB触摸屏使用232口通讯

G9SP和NB触摸屏使用232口通讯 实验时间&#xff1a;2023/9/7 实验设备&#xff1a;G9SP-N20S、CP1W-CIF01&#xff08;232串口选减板&#xff09;、NB5Q-TW00B、XW2Z-200T&#xff08;串口线&#xff09;&#xff0c;CP1W-20EDT1&#xff0c;D4GS-N4T&#xff08;安全门开关&a…

ntpd 和ntpdate 的区别

ntpd 和 ntpdate 都是用于进行网络时间同步的工具&#xff0c;但在功能和使用方式上有所不同。 ntpd&#xff08;Network Time Protocol daemon&#xff09;是 NTP 守护进程&#xff0c;用于在计算机网络中持续同步系统时钟与全球标准时间。ntpd 可以在计算机启动时自动启动&a…

【数据结构】二叉树的顺序结构实现及时间复杂度计算(二)

目录 一&#xff0c;二叉树的顺序结构实现 1&#xff0c;二叉树的顺序结构 2&#xff0c;堆的概念及结构 3&#xff0c;堆的接口实现 1&#xff0c;堆的创建 2&#xff0c;接口函数 3&#xff0c;初始化 4&#xff0c;销毁 5&#xff0c;是否增容 6&#xff0c;交换数据…

适用于Linux的Windows子系统(PHP搭建lmap、redis、swoole环境)

目录 前言 一、Windows安装Linux子系统 二、Ubuntu搭建PHP开发环境 1.PHP 安装 2.Apache2 安装 3.MySQL安装 4.Redis安装 5.Swoole安装 总结 前言 系列分为三章&#xff08;从安装到项目使用&#xff09;&#xff1a; 一、适用于Linux的Windows子系统&#xff08;系统安装步骤…

springboot整合mybatis实现增删改查(xml)--项目阶段1

目录 一、前言 二、创建项目 创建MySQL数据库和表 创建springboot项目 本文总体代码结构图预览 三、编写代码 &#xff08;一&#xff09;新建实体层属性类 &#xff08;二&#xff09;新建数据层mapper接口 &#xff08;三&#xff09;新建mapper的映射SQL&#xff08…