ThreadLocal的使用场景与原理理解

本文深入解析了ThreadLocal机制,阐述了其如何在线程内部存储和访问独立的变量副本,避免了线程间的数据竞争,特别介绍了ThreadLocalMap的实现原理及其在get()和set()方法中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、ThreadLocal机制

ThreadLocal模式提供一种在线程内共享变量(资源)的机制;也就是 同一个 ThreadLocal 所包含的对象(对ThreadLocal< String >而言即为 String 类型变量),在不同的 Thread 中有不同的副本。

二、ThreadLocal的原理

ThreadLocal是线程内部的数据存储类,通过它可以指定的线程中存储数据,数据存储以后,只有在指定线程中可以获取到存储的数据,对于其他线程来说则无法获取数据. 

threadLocal的源码实现,其中,get() 和 set() 方法是threadLocal的核心,所有的操作都是针对其中存储的数据

set()方法,其实就是在new ThreadLocalMap(); 每个线程都有自己的 ThreadLocalMap

get()方法

可以看到,当调用set()和get()方法时,都会先获取到当前线程,然后去 ThreadLocalMap中取出threadlocal中的值

其实最终,存储的数据是在 ThreadLocalMap的 Entry[]中。

WeakReference 意思是弱引用的意思

javaWeakReference参考: https://www.jianshu.com/p/f637b09e08c0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值