【Java】内存泄漏与内存溢出 学习总结

本文详细解释了内存泄露的概念,区分了内存泄露与内存溢出的不同,并深入探讨了Java中的内存泄露原因,包括静态集合类、各种连接未关闭及监听器未正确移除等情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 内存泄露(Memory Leak)是指一个不再被使用的对象或者变量还在内存中占有存储空间。

 内存溢出(OOM)是指程序在申请内存时没有足够的内存供使用,进而导致程序崩溃这是结果描述。

两者关系:  内存泄露(Memory Leak)最终会导致内存溢出。


       在C/C++语言中,内存泄露出现在开发人员忘记释放已分配的内存就会造成内存泄露。在java语言中引入垃圾回收机制,有GC负责进行回收不再使用的对象,释放内存。但是还是会存在内存泄露的问题。
内存泄露主要有两种情况:

       1.在堆中申请的空间没有释放。

       2.对象已不再被使用(注意:这里的不在被使用是指对程序来说没有用处,如数据库连接使用后没有关。但是还是存在着引用),但是仍然在内存中保留着。

 

        GC机制的引入只能解决第一种情况,对于第2种情况无法保证不再使用的对象会被释放。java语言中的内存泄露主要指第2种情况。


内存泄露的原因:

1.静态集合类。如HashMap和Vector。这些容器是静态的,生命周期和程序的生命周期一致,那么在容器中对象的生命周期也和其一样,对象在程序结束之前将不能被释放,从而会造成内存泄露。

2.各种连接,如数据库连接,网络连接,IO连接,不再使用时如果连接不释放容易造成内存泄露。

3.监听器,释放对象时往往没有相应的删除监听器,可能会导致内存泄露。


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值