ThreadLocal实现原理

ThreadLocal 是 Java 中实现线程封闭(Thread Confinement)的核心机制,它通过为每个线程创建变量的独立副本来解决多线程环境下的线程安全问题。

复制代码
Thread
└── ThreadLocalMap (threadLocals)  // 每个线程持有的专属Map
    ├── Entry[] table              // 哈希表结构
    │   └── Entry extends WeakReference<ThreadLocal<?>>
    │       ├── ThreadLocal<?> key  // 弱引用Key
    │       └── Object value       // 强引用Value
    └── 其他HashMap类似字段

threadlocal里的数据是怎么存储的?

每个线程内部有一个专属、私有的ThreadLocalMap(就是一个hashMap,底层用Entry数组存数据)

value:要保存的资源

调用set方法时,就是以当前ThreadLocal对象为key,以资源为value,放到ThreadLocalMap中

调用get方法时,就是以当前ThreadLocal对象为key,从ThreadLocalMap中取value

开发中一般把ThreadLocal声明为static,这样ThreadLocal对象是线程共享的,那key都共享了,不同线程取出来的value不就是同一个吗?

并不是。ThreadLocalMap是每个线程私有的

复制代码
[正确模型]
static ThreadLocal实例(作为Key)
├── 线程1的ThreadLocalMap: Entry(Key=ThreadLocal实例 → ValueA)
├── 线程2的ThreadLocalMap: Entry(Key=ThreadLocal实例 → ValueB)
└── 线程3的ThreadLocalMap: Entry(Key=ThreadLocal实例 → ValueC)

为什么key是弱应用?

要避免key的内存泄露问题

情况1:new Thread()的情况,用完正常销毁,那么ThreadLocalMap会被GC正常回收,不会出现内存泄露。

情况2:使用线程池结合ThreadLocal的情况(这个使用更常见,不需要频繁创建,可以复用),线程池中的线程不会销毁会一致复用。

弱引用Key,GC时ThreadLocal无强引用,回收Key防止Map持续增长

key只有弱引用时,只要发生了垃圾回收,ThreadLocalMap就会回收,避免内存泄露问题


ThreadLocalMap中如何清理大量为null的数据 ?

在调用set、get、remove方法时,就会遍历数组,清除为null的entry,然后通过线性探测重新处理hash冲突

为什么value是强引用?

将数据存到value中,是为了要用它,如果不是强引用,就会被GC回收

那value怎么回收呢?

不回收会导致内存泄露

所以,在使用完ThreadLocal后必须断开强引用,即调用remove方法手动断开强引用,让gc把它回收了

相关推荐
天天进步20151 分钟前
Tunnelto 源码解析 #1:从 tunnelto --port 8000 看内网穿透的完整链路
开发语言
土狗TuGou8 分钟前
SQL内功笔记 · 第6篇:窗口函数的使用ROW_NUMBER等
java·数据库·后端·sql·mysql
啄缘之间8 分钟前
8.【学习】工业级详细接口约束&覆盖率
开发语言·笔记·学习·uvm·sv
Chase_______10 分钟前
【Java基础核心知识点全解·09】Java 内存布局与垃圾回收详解:栈、堆、栈帧、GC Roots 与对象回收
java·开发语言
武子康13 分钟前
Java-11 深入浅出 MyBatis 一级缓存详解:从原理到失效场景 Executor
java·后端
寻道码路27 分钟前
LangChain4j Java AI 应用开发实战(十):Embedding 模型与文本分类 - 语义向量化
java·人工智能·ai·embedding
江南十四行27 分钟前
并发编程(四)
开发语言·python
葱卤山猪30 分钟前
C++17 联合体
开发语言·c++
折哥的程序人生 · 物流技术专研30 分钟前
Java 23 种设计模式:从踩坑到精通 | 抽象工厂 —— 支付/收款如何成套创建?跨平台 UI 如何一键换肤?
java·开发语言·后端·设计模式
方也_arkling33 分钟前
【Java-Day11】抽象类和抽象方法
java·开发语言