本篇内容主要讲解“java中ThreadLocal核心方法如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java中ThreadLocal核心方法如何使用”吧!

创新互联长期为近千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为肃南裕固族自治企业提供专业的网站建设、成都网站设计,肃南裕固族自治网站改版等技术服务。拥有10多年丰富建站经验和众多成功案例,为您定制开发。
1、get()方法
(1)获取当前用的线程,并找到线程关联的threadLocalMap
(2)threadLocalMap为空则进行初始化一个新的并返回
(3)threadLocalMap不为空则根据threadlocal作为key查找Entry
(4)若Entry不为空则返回entry对应的值,否则执行第二条
public T get() {
// 获取当前线程
Thread t = Thread.currentThread();
ThreadLocalMap map = getMap(t);
//若当前线程关联的ThreadLocal不为空则查询
if (map != null) {
//根据threadLocal查询对应的Entry
ThreadLocalMap.Entry e = map.getEntry(this);
if (e != null) {
@SuppressWarnings("unchecked")
T result = (T)e.value;
return result;
}
}
return setInitialValue();
}
private T setInitialValue() {
//默认返回null值
T value = initialValue();
Thread t = Thread.currentThread();
ThreadLocalMap map = getMap(t);
//如果当前调用线程关联的ThreadLocalMap为空则创建,否则设置值进去
if (map != null)
map.set(this, value);
else
//new ThreadLocalMap(this,value)
createMap(t, value);
return value;
}
private Entry getEntry(ThreadLocal> key) {
//根据key获取其在数组的下标位置
int i = key.threadLocalHashCode & (table.length - 1);
Entry e = table[i];
if (e != null && e.get() == key)
return e;
else
return getEntryAfterMiss(key, i, e);
}
private Entry getEntryAfterMiss(ThreadLocal> key, int i, Entry e) {
Entry[] tab = table;
int len = tab.length;
//数组下标的Entry不为空且关联的threadlocal与查找的threadlocal不一致
while (e != null) {
ThreadLocal> k = e.get();
//entry关联的threadlocal与查找的相等则直接返回
if (k == key)
return e;
if (k == null)
//关联的threadlocal为空,则触发清理key为null的Entry并重新进行rehash旧Entry数组的元素
//threadLocalMap的hash冲突与hashMap的冲突处理方式不一致,hashMap使用的是链表地址法,
//而threadLocalMap使用的开放地址法——线性探测,即顺序查找下一位置或者遍历全表,效率较低
expungeStaleEntry(i);
else
//递增下标i的值进行下一轮的查找
i = nextIndex(i, len);
e = tab[i];
}
return null;
}2、remove()方法
(1)获取当前用的线程,并找到线程关联的threadLocalMap
(2)若不为空则删除threadLocalMap中关联的值,否则啥也不做
//ThreadLocal
public void remove() {
ThreadLocalMap m = getMap(Thread.currentThread());
if (m != null)
//删除当前threadLocal对象关联的Entry
m.remove(this);
}
//ThreadLocalMap
private void remove(ThreadLocal> key) {
Entry[] tab = table;
int len = tab.length;
int i = key.threadLocalHashCode & (len-1);
for (Entry e = tab[i];
e != null;
e = tab[i = nextIndex(i, len)]) {
if (e.get() == key) {
e.clear();
expungeStaleEntry(i);
return;
}
}
}到此,相信大家对“java中ThreadLocal核心方法如何使用”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!