一、ThreadLocal的概念
ThreadLocal是线程的局部变量,是一种多线程间并发访问变量的解决方案。与synchronized加锁的方式不同,ThreadLocal完全不提供锁,而是使用以空间换时间的手段,为每一个线程提供变量的独立副本,以保障线程安全。
从性能上说,ThreadLocal不具备绝对的优势,在并发不是很高的时候,加锁的性能可能会更好,但作为一种与锁完全无关的线程安全解决方案,在并发量比较高或者竞争激烈的场景下,使用ThreadLocal可以在一定程度上减少锁竞争。
二、ThreadLocal的使用示例
public class ConnThreadLocal {
public ThreadLocal<String> th = new ThreadLocal<String>();
public void setTh(String value){
th.set(value);
}
public void getTh(){
System.out.println(Thread.currentThread().getName() + ":" + this.th.get());
}
public static void main(String[] args) throws InterruptedException {
final ConnThreadLocal ct = new ConnThreadLocal();
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
ct.setTh("张三");
ct.getTh();
}
}, "t1");
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(1000);
ct.getTh();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}, "t2");
t1.start();
t2.start();
}
}
执行上述代码,其输出结果为:
t1:张三
t2:null
从结果可以看出每一个线程里面都会有一个属于自己的ThreadLocal,不会与其它线程共享。
三、真实场景怎么用ThreadLocal
模拟一个多线程的场景,先创建一个线程池,然后在这个线程池里面去执行格式化时间的这么一个操作:
public static