黑马程序员JVM系列学习——内存溢出产生的原因

本文探讨了代码中常见的内存泄漏问题,如equals()和hashCode()不当重写导致的HashMap问题,内部类引用外部类的内存保持,ThreadLocal的生命周期管理,String的intern方法以及资源未关闭等。同时,也提到了如何通过并发请求管理和静态字段优化内存使用。
摘要由CSDN通过智能技术生成

原因一:代码中的内存泄漏

1.equals()和hashCode()导致的内存泄漏

定义新类时没有重写正确的equals()和hashCode()方法,在使用HashMap的场景下,如果使用这个类对象作为key,HashMap在判断类是否已经存在时会用到这些方法,如果重写不正确则会导致相同的数据被保存多份。如果没有重写会使用其父类Object类中的实现。

由于没有重写方法,在第一次时正常加入,第二次时会使用Object中的默认算法,该算法为使用一个随机数加上三个确定的值运算出来的,所以后面的与第一次应该不同。所以被分到了数组不同的位置。

2.内部类引用外部类

内部类:即在一个类内部定义的类

(1)

while循环中只保留内部类,外部类对象不再使用

解决方式:内部类改为静态的,因为静态内部类不会引用外部类对象

(2)Outer不会被回收

3.ThreadLocal的使用

线程池里面的线程是否回收或者什么时候回收完全由线程池里面的参数决定。若线程没有回收且没有调用remove,则会占用一定空间。

4.String的intern方法

5.通过静态字段保存对象

上述第二点的好处:如果程序启动后有些对象一直没有使用,则这些对象不会被创建,节省一定空间。

6.资源没有正常关闭

原因二:并发请求问题

即用户发送请求向Java应用获取数据,正常情况下Java应用将数据返回后,这部分数据就可以在内存中被释放。

​​​​​​​

  • 14
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值