我们在使用ThreadLocal的时候,不可避免的会遇到内存的问题。那么在ThreadLocalMap中,使用的是弱引用的方式。我们都知道引用时有两种方式可以选择的,对于ThreadLocalMap使用弱引用的原因,很多人都保有怀疑的态度。下面我们就这两种引用进行对比,然后阐述使用弱引用的原因。
1、强弱引用对比
如果key使用强引用,可以有这样子的对比:
(1)key使用强引用:在当前ThreadLocal没有外部强引用时,ThreadLocalMap的Entry还保持着ThreadLocal的强引用,ThreadLocal不会被GC。如果没有手动删除,并且当前线程结束了,就导致了Entry的内存泄漏。(有点类似用static修饰ThreadLocal的情况)
(2)key使用弱引用:在当前ThreadLocal没有外部强引用时,ThreadLocalMap只保持着ThreadLocal的弱引用,无论有没有手动删除,ThreadLocal都会被GC,只要下一次cleanSomeSlots(),expungeStaleEntry()被调用,value就会被清除,否则也会引起内存泄漏。
2、使用弱引用的原因
通过这样子的对比,我们可以得出:
(1)由于ThreadLocalMap的生命周期和Thread一样长,如果没有手动删除,都有可能会导致内存泄漏,但是弱引用多了一层保障:使用弱引用时,ThreadLocal无论如何都不会内存泄漏,只要下一次cleanSomeSlots(),expungeStaleEntry()被调用,value就会被清除。
(2)ThreadLocal引起的内存泄漏的根源,是因为ThreadLocalMap的生命周期跟Thread一样长,并且在线程结束之前,没有删除key,并不是因为弱引用。
以上就是java ThreadLocalMap使用弱引用的原因分析,经过本篇对于两种引用的对比,相信大家已经能够对ThreadLocalMap的引用方法有所明确。更多Java学习指路:java教程
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)