ThreadLocal简介
多钱程访问同一个共享变量时特别容易出现并发问题,特别是在多个线程需要对一个共享变量进行写入时,为了保证线程安全,一般使用者在访问共享变量的时候需要进行额外的同步措施才能保证线程安全性。
ThreadLocal是除了加锁这种同步方式之外的一种保证一种规避多线程访问出现线程不安全的方法,当我们在创建一个变量后,如果每个线程对其进行访问的时候访问的都是线程自己的变量这样就不会存在线程不安全问题。
ThreadLocal是JDK包提供的,它提供线程本地变量,如果创建一个ThreadLocal变量,那么访问这个变量的每个线程都会有这个变量的一个本地副本,在实际多线程操作的时候,操作的是自己本地内存中的变量,从而规避了线程安全问题。
ThreadLocal简单使用
开启两个线程,在每个线程内部设置了本地变量的值,然后调用print方法打印当前本地变量的值。如果在打印之后调用本地变量的remove方法会删除本地内存中的变量。
public class ThreadLocalTest {
public static ThreadLocal<String> local = new ThreadLocal<>();
public static void print(String content){
// 打印当前线程中本地内存中本地变量的值
System.out.println(content + ":" + local.get());
// 清除本地内存中的本地变量
local.remove();
}
public static void main(String[] args) {
Thread threadA = new Thread(new Runnable() {
@Override
public void run() {
// 设置线程A中本地变量的值
local.set("线程A的本地变量");
// 调用打印方法
print("threadA");
// 打印本地变量
System.out.println("线程A本地变量移除后 : " + local.get());
}
});
Thread threadB = new Thread(new Runnable() {
@Override
public void run() {
local.set("线程A的本地变量");
print("threadB");
// 打印本地变量
System.out.println("线程B本地变量移除后 : " + local.get());
}
});
threadA.start();
threadB.start();
}
}
运行结果:
threadA:线程A的本地变量
threadB:线程A的本地变量
线程A本地变量移除后 : null
线程B本地变量移除后 : null
如果当前线程一直不消亡 那么这些本 变量会 直存在 所以可能会造成内存溢出,因此使用完毕后要记得 ThreadLocal remove 方法 除对应线程 threadLocals 中的本地变量。