**
面试中经常被面试官问到threadLocal是什么?请说下你对它的理解。带着这个疑问,今天来为大家简答下。
ThreadLocal并不是一个Thread,而是Thread的局部变量
那ThreadLocal到底有什么用呢?
多线程访问同一个共享变量的时候容易出现并发问题,特别是多个线程对一个变量进行写入的时候,为了保证线程安全,一般使用者在访问共享变量的时候需要进行额外的同步措施才能保证线程安全性。ThreadLocal是除了加锁这种同步方式之外的一种保证一种规避多线程访问出现线程不安全的方法,当我们在创建一个变量后,如果每个线程对其进行访问的时候访问的都是线程自己的变量这样就不会存在线程不安全问题。
ThreadLocal是JDK包提供的,它提供线程本地变量,如果创建一乐ThreadLocal变量,那么访问这个变量的每个线程都会有这个变量的一个副本,在实际多线程操作的时候,操作的是自己本地内存中的变量,从而规避了线程安全问题,如下图所示
**
**代码示例
public class ThreadLocalDemo
//这里创建一个线程变量并调用ThreadLocal的initialValue()方法初始化值
private static ThreadLocal<Integer> numLocal = new ThreadLocal<Integer>(){
protected Integer initialValue(){
return 0;
}
};
public static void main(String[] args){
Thread[] threads = new Thread[5];
//循环创建5个线程并为线程进行+5操作
for (int i = 0; i < threads.length; i++){
threads[i] = new Thread(()->{
int intValue = numLocal.get().intValue();
intValue+= 5;
//set方法赋值
numLocal.set(intValue);
//下面的get()方法是ThreadLocal的获取值方法
System.out.println(Thread.currentThread().getName() + ":" + numLocal.get());
},"Thread-" + i);
}
//这里循环启动上面循环创建的5个线程
for (int i = 0; i < threads.length; i++){
threads[i].start();
}
}
}
上述代码执行结果如下:
Thread-0:5
Thread-4:5
Thread-1:5
Thread-3:5
Thread-2:5
从代码运行结果可以看出5个线程执行打印的结果都是5。说明5个线程操作的变量不是同一个变量,就是说ThreadLocal给5个线程在本地分别创建了一个变量副本。所以结果都是5。而不是5,10,15,20,25.
注意:如果使用ThreadLocal时,先进行get之前,必须先set,否则会报空指针异常