ThreadLocal 底层用entry存储 键值对 本身对象为key 数据为value
每一个只能存一个键值对
如果要存储多份信息的话 那么我们就要定义多个threadlocal 是jdk提供的
一 JDK8前的设计
每个 ThreadLocal 都创建一个 Map,然后用线程作为 Map 的 key,要存储的局部变量作为 Map 的 value,这样就能达到各个线程的局部变量隔离的效果。
二 JDK8后的设计
每个 Thread 维护一个 ThreadLocalMap,这个 Map 的 key 是 ThreadLocal 实例本身,value 才是真正要存储的值 object。
具体过程如下
1 每个 Thread 线程内部都有一个 Map (ThreadLocalMap)。
2 Map 里面存储 ThreadLocal 对象(key)和线程的变量副本(value)。
3 Thread 内部的 Map 是由 ThreadLocal 维护的,由 ThreadLocal 负责向 map 获取和设置线程的变量值。
4 对于不同的线程,每次获取副本值时,别的线程并不能获取到当前线程的副本值,形成了副本的隔离,互不干扰。
为什么引入threadLocal
当并发操作时 如果我们需要用到变量,
那么多线程同时操作就会导致数据有问题
那么我们就引入每个线程都有自己的临时变量,在线程被销毁的时候这个变量也就不存在