ThreadLocal的原理

ThreadLocal原理

1ThreadLocal是一个工具类,为每个线程提供自己专属的本地变量

2ThreadLocal底层是通过ThreadLocalMap实现的,每个Thread对象中存在一个ThreadLocalMap,Map的key为ThreadLocal对象 ,Map的value为要缓存的值

ThreadLocal内存泄露问题是怎么产生的?

ThreadLocalMap 中使用的 key 为 ThreadLocal 的弱引用,而 value 是强引用。,在垃圾回收的时候,key 会被清理掉,而 value 不会被清理掉。假如我们不做任何措施的话,value 永远无法被 GC 回收,这个时候就可能会产生内存泄露。使用完 ThreadLocal方法后最好手动调用remove()方法(清除ThreadLocalMap中的带有key为该ThreadLocal对象的Entry)。

ThreadLocal的应用场景

当一个共享变量是共享的,但是需要每个线程互不影响,相互隔离,就可以使用ThreadLocal

相关推荐
段小二3 小时前
服务一重启全丢了——Spring AI Alibaba Agent 三层持久化完整方案
java·后端
段小二4 小时前
Agent 自动把机票改错了,推理完全正确——这才是真正的风险
java·后端
itjinyin4 小时前
ShardingSphere-jdbc 5.5.0 + spring boot 基础配置 - 实战篇
java·spring boot·后端
丶小鱼丶4 小时前
Java虚拟机【JVM】
java·jvm
csdn2015_4 小时前
IDEA配置Continue
java·ide·intellij-idea
aq55356005 小时前
C语言、C++和C#:三大编程语言核心差异详解
java·开发语言·jvm
老马95275 小时前
opencode4-在已有项目中增加修改功能
java·后端·ai编程
Moe4885 小时前
Spring AI:结构化输出
java·后端·面试
sthnyph6 小时前
TypeScript 与后端开发Node.js
java
逻辑驱动的ken6 小时前
Java高频面试考点场景题08
java·开发语言·面试·求职招聘·春招