threadlocal弱引用
时间: 2023-08-28 20:23:11 浏览: 88
ThreadLocal中使用弱引用的原因是为了解决内存泄漏的问题。当我们将ThreadLocal对象置为null后,如果ThreadLocalMap中的entry的key仍然是强引用,那么对象A就无法被回收。因为ThreadLocalMap中的entry会持有key的引用,直到该线程被销毁。然而,线程很可能会被放到线程池中重复使用,导致内存泄漏。
通过使用弱引用,当ThreadLocal对象的强引用被取消后,它就只剩下一个弱引用了。弱引用在JVM触发GC回收时会被回收。因此,在下一次调用get()、set()、remove()方法时,ThreadLocalMap中的key为null的entry就会被删除,实现了惰性删除和释放内存的作用。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [ThreadLocal的弱引用](https://blog.csdn.net/AAA821/article/details/103794227)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *3* [Threadlocal中的弱引用到底是怎么一回事](https://blog.csdn.net/m0_59602613/article/details/123759760)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文