threadLocal:
threadLocal是并发问题中的一种解决思路,在加锁的方式中,都是以时间换取空间的策略,但是threadLocal是以空间换取时间,在并发问题中,所解决的问题是不同的。前者偏向于线程之间的数据有前后联系,后者偏向于每个线程都需要一种资源,但是线程之间的数据没有关;
源码浅析:
threadLocal内部的实现还是使用map来实现的,每个threadLocal内部都有一个ThreadLocalMap对象,内部存储了一个entry数组,用来存放threadLocal中不同的数据,entry中的键值对是当前的threadLocal和value值。
put数据时,若之前存在数据,更新以下数据,否则创建新的entry,加入entry数组。
public void set(T value) { Thread t = Thread.currentThread(); ThreadLocalMap map = getMap(t); if (map != null) map.set(this, value); else createMap(t, value); }
ThreadLocalMap(ThreadLocal firstKey, Object firstValue) { table = new Entry[INITIAL_CAPACITY]; int i = firstKey.threadLocalHashCode & (INITIAL_CAPACITY - 1); table[i] = new Entry(firstKey, firstValue); size = 1; setThreshold(INITIAL_CAPACITY); }