Java内存泄漏真实案例

内存泄漏:当不再需要一个对象时,垃圾收集器会回收它;如果不需要的对象一直在产生而不被收回,就称作“内存泄漏”。

 

以下为本人在工作中遇到的内存泄漏的案例:

 

1、对于大量的请求,使用了Executors.newCachedThreadPool()返回的线程池。

这个线程池是没有界限的,如果每个线程处理时间较长,而且请求很多,会无限吃内存。

 

2、对于数据库查询,使用MyBatis的openSession获取SqlSession,然后忘记了close。

SqlSession推荐在try-catch-finally语句的finally语句块中显式地调用close()方法

 

以下是从网上收集的其他泄漏场景:

3、向静态集合中添加大量元素的引用,这些对象就算不再使用,也不会被GC主动回收的。从而导致集合内存泄漏。

 

解决方案:

1、WeakHashMap,存放于其中的键值对,如果没有被使用,会在以后的时间里被GC自动回收。

2、WeakReference: 当一个对象仅仅被weak reference指向, 而没有任何其他strong reference指向的时候, 如果GC运行, 那么这个对象就会被回收.

WeakReference<String> nameRef = new WeakReference<String>(name);

当要获得weak reference引用的object时, 首先需要判断它是否已经被回收: nameRef.get()

3、SoftReference: 软引用。

当一个对象具有软引用时,在内存空间足够的情况下不会被回收。如果内存空间即将耗尽、就要抛出oom异常的时候,GC才会将该引用对象收回。

 

转载于:https://www.cnblogs.com/shuada/p/9168149.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值