内存泄漏?内存溢出?

内存泄漏: 一个不再被程序使用的对象或者变量还在内存中占有存储空间
一次内存泄漏可能不会出现什么影响,但是多次内存泄漏堆积后的后果就是内存溢出
内存溢出: 指程序申请内存时,没有足够的内存供申请者使用,或者说给了一块存储int类型的数据的存储空间,但是你却用来存储long类型的数据,结果就是内存不够用,此时就会报OOM,即内存溢出
二者的关系:
1:内存泄漏的堆积最终会导致内存溢出
2:内存溢出就是你要的内存空间超过了系统实际分配的空间,此时系统相当于没法满足你的需求,就会报内存溢出的错误
3:内存泄漏是指向系统申请分配内存进行使用(new)可是使用完却没有归还(delete),结果你申请到的哪一块内存你自己也不能再访问(你把地址丢了),而系统也不能再次将它分配给需要的程序,就相当于你租了一个带钥匙的柜子,你存完东西之后把柜子锁上,但是你把钥匙丢了或者没有将钥匙归还,结果就是这个柜子无法给任何人继续使用,也无法被垃圾回收器回收,因为找不到他的信息。
4:内存溢出:一个盘子只能装四个果子,结果你装了5个,有一个掉到地上不能吃了,这个就是内存溢出,比方说栈:栈满时再做进栈必定会产生内存溢出,叫上溢,栈空的时候你再继续弹栈也会产生溢出,称为下溢,就是分配的内存不足以放下数据序列,称为内存溢出,就会报错
由于java的JVM引入了垃圾回收机制,垃圾回收器会自动回收不再使用的对象,JVM使用引用计数器和可达性分析算法来判断对象是否不再使用的对象,本质都是判断一个对象是否还被引用。那么对于这种情况,代码的实现不同就会出现很多内存泄漏的问题(JVM误以为此对象还在引用中,无法回收,造成内存泄漏)
应该注意哪些情况容易内存泄漏???
1:静态集合类,如hashmap、linkedlist等,如果这些容器为静态的,那么它们的生命周期与程序一致,则容器中的对象在程序结束前不能被释放,从而引起内存泄漏,简而言之,长生命周期的对象持有生命周期对象的引用,尽管短生命周期的对象不再使用,但是因为长生命周期对象持有它的引用而导致不能被回收
2:各种连接,如数据库连接,网络连接和IO连接等。在对数据库进行操作的过程中,首先需要建立与数据库的连接,当不再使用时,需要调用close方法来释放与数据库的连接。只有连接被关闭后,垃圾回收才会回收对应的对象,否则如果在访问数据库过程中,对Connection、Statement或ResultSet不显示地关闭,将会造成大量的对象无法被回收,从而引起内存泄漏。
3:变量不合理的作用域。一般而言,一个变量的定义的作用范围大于其使用范围,很有可能造成内存泄漏。另一方面,如果没有及时地吧对象设置为null,很有可能导致内存泄漏
4:内部类持有外部类。如果一个外部类的实例对象的方法返回了一个内部类的实例变量,这个内部类对象被长期引用了,即使那个外部类实例对象不再被使用,但由于内部类持有外部类的实例对象,这个外部对象将不会被垃圾回收,这也会造成内存泄漏
5:改变哈希值。当一个对象被存储进hashSet集合中以后,就不能修改这个对象中的那些参与计算哈希值的字段了,否则对象修改后的哈希值与最初存储进hashSet集合中的哈希值不同,在这种情况下,即使在contains方法使用该对象的当前引用作为的参数去hashSet集合中检索对象,也将返回找不到对象的结果,这也会导致无法从hashSet集合中单独删除当前对象,造成内存泄漏

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值