对于ThreadLocal的一些个人理解

ThreadLocal为什么会导致内存泄漏?

首先给出结论:在ThreadLocal引起的内存泄漏问题中,真正导致内存泄漏的是value,而不是key(ThreadLocal对象本身)

要搞明白一件事情,在Java中一个对象在什么情况下不会被GC掉?根据可达性分析法,如果一个对象存在一个GCRoot对它的引用链, 它就可以保证不被GC回收。

ThreadLocal的本质是每个线程维护一个ThreadLocalMap,并且ThreadLocalMap的每一个Entry都是以这个ThreadLocal对象作为Key(ThreadLocalMap上对这个ThreadLocal对象的引用是弱引用),但是这个Entry上对Value的引用为强引用。

在new一个ThreadLocal对象后(记为tl),这时候这个对象存在一个强引用。在调用这个对象的set或get方法后,又会额外的增加一个ThreadLocalMap对它的弱引用**(WeakReference)。一个对象如果同时存在强引用和弱引用的情况下,是以强引用为主导,即不会被GC回收掉。如果某一时刻tl这个对象为空,也就是JVM堆上的对象失去了强引用,在下一次GC时,这个ThreadLocal对象就会被GC掉。但是由于Value是强引用的,则始终存在着Thread Ref → Thread → ThreadLocalMap→Entry→value的这样一条强引用链(逻辑上不可达,但物理上可达),导致这个value对象既无法被访问,又无法被回收,从而导致内存泄漏。也就是说将ThreadLocal作为弱引用其实是在一定程度上缓解了内存泄漏的问题。

如何避免?

在使用完ThreadLocal时,一定要记得使用Remove()方法,避免造成内存泄漏。

全部评论
后面几句我能不能理解为key不会立刻被gc所以这段时间内value是泄露的,但因为key是弱引用所以很快会被gc,一定程度上缓解了泄露问题
2 回复 分享
发布于 11-07 23:28 美国
这玩意能不能在线程池使用?
1 回复 分享
发布于 11-07 15:26 上海
很详细,感谢
1 回复 分享
发布于 11-07 23:37 江苏
所以你能回答key少线程少,value小为什么也会出现内存泄露?
点赞 回复 分享
发布于 11-07 23:46 北京
那么为什么要这么设计呢,为什么要一个弱一个强引用,而不是都是强或都是弱
点赞 回复 分享
发布于 11-08 14:50 福建
那为什么要把他设置成弱引用呀
点赞 回复 分享
发布于 11-19 09:04 北京

相关推荐

想起来研0刚刚进组那会儿,住的是一个离学校通勤要一个小时的公寓,每天下班回去后,就只想躺着,心里还一直在想白天的代码怎么改……读研这两年多,感觉跟找了个班上没啥区别,无非是没有钱,无论是实习还是最近出差在合作单位里,能明显感觉到工作产生的负面情绪,是完全无法通过在工作/职场中通过任何的努力或者调整而得到什么所谓的改善,它只能被你工作以外的生活对冲掉。最近刷小红书,会看到一些带着职场关键词的信息,就是一些教学,说什么“职场智慧”,教你怎么调整心态减少内耗。比如什么“打工人要佛系一点,不要太有责任心”,“别在工作里找人生意义”,还有那句经典的“带着离职的心态上班,瞬间治愈焦虑”……你说这些东西,有用吗?嗯……可能吧,但就像给大病贴创可贴——管不了根本。只要你一心扑在工作上,把它当成生活的核心,下了班就只会刷手机、倒头睡觉,那你情绪不崩才怪呢。你每在职场受的一丁点委屈,都会被生活里无限放大,结果你根本没法脱身。那换个思路——上班难免糟心,那就让它糟心呗,咱也别指望它突然变香甜。关键是,下了班你要整点能让自己心花怒放的事情!追星也好,撸猫也罢,约饭喝酒、买新衣服、找拍照机位、琢磨下一站旅行去哪,哪怕就是天天等快递拆盲盒……有了这些“精神支点”,你会发现你的世界变大了,生活评价体系更丰富了,工作自然就缩成了一个小角落,那由它带来的烦恼就会被你更丰富的生命体验所稀释掉。所以啊,真要是工作让你不开心了,别再硬撑着非要在职场找出口、死气白咧的琢磨他了。想要活得快乐,答案其实很简单:去找到那些能让你发光的生活热爱,人生的解药,全都在工作之外#工作两年想退休了##我的求职思考##如何排解工作中的焦虑##牛客解忧铺#
点赞 评论 收藏
分享
8 38 评论
分享
牛客网
牛客企业服务