threadLocal浅析

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);
}

猜你喜欢

转载自blog.csdn.net/qq_32182461/article/details/81040604