JVM-内存泄漏和内存溢出的区别?

本文详细介绍了内存泄漏和内存溢出的区别,以及在Java中造成这两种问题的原因。内存泄漏指程序申请内存后未能释放,导致可用内存逐渐减少;内存溢出则是程序请求内存时因空间不足引发的错误。常见的内存泄漏原因包括未使用的引用、未关闭的数据源、静态实例等,而内存溢出可能是由于内存泄露、大对象创建或物理内存不足等。了解这些原因有助于优化Java应用程序的内存管理。
摘要由CSDN通过智能技术生成

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

    内存泄漏(memory leak):是指程序在申请内存后,无法释放已申请的内存空间,新申请的内存在增加,而没有内存释放,迟早被占光,导致后面程序无法申请到内存。

内存溢出(out of memory):是指程序在申请内存的时候,发现没有足够的空间,导致out memeory。

JVM造成以上两种溢出的原因可能?

    内存泄漏(memory leak)

     引用值未被使用到:

数据源未关闭,比如dataSource.getConnection();

单例对象,因为对象对外部是有所有引用的,但是没有使用,导致一直无法被jvm回收;

大量的静态实例,比如很多动态放到内存内的字符串,并且还是static的;

...

    内存溢出(out of memory)

java虚拟机堆内存不够:有可能是由于内存泄露导致一直占用着堆内存,导致新的对象无法分配到内存导致OOM;

大对象:内存中突然或者持续创建大量的大对象放到堆中,导致OOM;

物理内存不足:由于物理内存的空间不足导致OOM;

...

参考文章:

https://blog.csdn.net/keneyr/article/details/96369149

https://blog.csdn.net/weixin_43689480/article/details/96474346

https://www.cnblogs.com/rude3knife/p/13570423.html

https://www.cnblogs.com/panxuejun/p/8630779.html

https://www.cnblogs.com/ixenos/p/5674702.html

 

往期推荐

JVM可达性分析是怎么GC的?

JVM (标记-清除算法、复制算法、标记-整理算法、分代收集算法、分区算法)

JVM垃圾收集器(GC)有哪些?

JVM执行引擎(Execution Engine)

JVM-直接内存(Direct Memory)

逃逸分析(Escape Analysis)技术


 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值