大家好,这里是淇妙小屋,一个分享技术,分享生活的博主
后续会发布更多MySQL,Redis,并发,JVM,分布式等面试热点知识,以及Java学习路线,面试重点,职业规划,面经等相关博客
转载请标明出处!


有以下三种情况
绿色执行路径
蓝色执行路径
红色执行路径
基本逻辑同get()
Entry继承自WeakReference,注意Entry不是弱引用,Entry中的reference才是弱引用,这个弱引用避免了ThreadLocal的内存泄漏

我们一般使用线程池,线程的生命周期很长,所以Thread引用会存在很长一段时间
如果我们不使用ThreadLocal了,将ThreadLocal引用设置为null(或者方法执行完毕,ThreadLocal引用弹出栈)

没有了ThreadLocal引用,ThreadLocal无法被访问到,线程就无法使用ThreadLocal,此时GC应该要回收掉ThreadLocal对象
若Entry的引用是强引用,会导致ThreadLocal无法被回收,造成内存泄漏
所以Entry的引用必须是弱引用,这样一旦发生GC,ThreadLocal就会被回收
ThreadLocal一旦被回收,那么Entry对象的reference就为空,此时Entry也是无用的,应该被回收掉——expungeStaleEntry()会回收掉那么reference为null的Entry对象(详情看源代码或者0. 类图和get()方法调用图)
许多个地方都会调用expungeStaleEntry()来清除无用的Entry,例如get()和扩容
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。