博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
理解ThreadLocal —— 一个map的key
阅读量:4972 次
发布时间:2019-06-12

本文共 1233 字,大约阅读时间需要 4 分钟。

作用:

当工作于多线程中的对象使用ThreadLocal维护变量时,threadLocal为每个使用该变量的线程分配一个独立的变量副本。

接口方法:

protected T initialValue() //初始化数据。延迟调用方法,在线程第一次调用get或set时才执行,并且只执行1次。默认返回null。public T get()  //获取当前线程的变量public void set(T value) //设置当前线程的变量public void remove()  //删除当前线程的变量

 

查看ThreadLocal的源代码,还是比较简单的。
先看get方法: 
public T get() {    Thread t = Thread.currentThread();    ThreadLocalMap map = getMap(t);    if (map != null) {        ThreadLocalMap.Entry e = map.getEntry(this);        if (e != null)            return (T)e.value;    }    return setInitialValue();} ThreadLocalMap getMap(Thread t) {    return t.threadLocals;}

   从ThreadLocalMap中取数据,有数据就返回,没有数据就设置默认值并返回(所以说initialValue是延迟调用)。这里的ThreadLocalMap是当前线程的属性,map的key是当前ThreadLocal对象。 所以,get其实是一个根据key查找value的方法,只是存储的map,隐藏在当前Thread里面。

 

举个栗子:

初始化如下:三个threadLocal对象。

如下图,第一个数据存放在当前线程Thread@1的threadLocals,即map【ThreadLocalMap@432】中。key为this,即ThreadLocal@428,即图1的firstNum。

如下图,第二个数据存放在当前线程Thread@1的threadLocals,即map【ThreadLocalMap@432】中。key为this,即ThreadLocal@430,即图1的secondNum。

如下图,第三个数据存放在当前线程Thread@1的threadLocals,即map【ThreadLocalMap@432】中。key为this,即ThreadLocal@429,即图1的thirdNum。

 

完毕。

——————————————————————————————————————

重要的是把事情说清楚,而我正在努力做这样的事情。请大家多多指教。

转载于:https://www.cnblogs.com/shoren/p/java.html

你可能感兴趣的文章
RandomAccessFile文件读写
查看>>
0x28 IDA*
查看>>
为什么设置overflow为hidden可以清除浮动带来的影响
查看>>
数据库
查看>>
Stm32利用SWD下载的设置
查看>>
Common Lisp 在 Windows 上的开发环境比较
查看>>
在知道管理员密码的情况下强制编辑文件sudoers
查看>>
solr的简单部署:在tomcat中启动slor
查看>>
ACM最大子串和问题
查看>>
ACM 最大公共子序列
查看>>
JDBC 入坑
查看>>
android学习
查看>>
c的cl 编译dll,C#调用dll
查看>>
微信公众号为什么要加粉?流量,广告,KPI,吸粉,增粉
查看>>
在vue项目中引入jquery
查看>>
TOP命令各个参数代表意义详解
查看>>
js中js数组、对象与json之间的转换
查看>>
[ubuntu]给ubuntu server安装xubuntu(xfce)窗口管理器
查看>>
poj 1066 Treasure Hunt
查看>>
QProcess 进程类—调用外部程序
查看>>