用于不同线程下存储共享的数据变量,线程开启时接收当前的共享变量,其他线程开启时也可以接收,他们之间不会影响并且该threadLocal会作用在整个线程生命之间,也就意味着无论线程执行到哪一个代码类都能获取到存储的属性,相当于线程创建的属性,可用在该线程所要执行的任何对象的方法上获取,如前端请求开启线程-》controller-》service-》dao都是线程要执行的地方,而线程开启时创建了过Threadlocal则后继的执行的类区域都能获取到线程的ThreadLocal的存储对象,而且线程与线程之间不会干扰,如在拦截器里拦截请求获取前端的参数值放入该拦截器的ThreadLocal中,在并发的时候,每个开启的线程都会执行到各自的拦截器创建各自的threadLocal,接收前端相同的变量,到线程内部时这个变量在多线程中互不干扰,同一个线程上下文可以任何类内的任何方法获取。
相关推荐
麻芝汤圆7 分钟前
MapReduce 的广泛应用:从数据处理到智能决策努力的搬砖人.7 分钟前
java如何实现一个秒杀系统(原理)哈哈哈哈哈哈哈哈哈...........14 分钟前
【java】在 Java 中,获取一个类的`Class`对象有多种方式fallwind_of_july19 分钟前
java项目分享-分布式电商项目附软件链接武昌库里写JAVA35 分钟前
Golang的消息中间件选型工一木子38 分钟前
大厂算法面试 7 天冲刺:第6天-树与图深度剖析——高频算法面试题 & Java 实战振鹏Dong1 小时前
字符串——面试考察高频算法题小小鸭程序员2 小时前
Spring Boot项目连接MySQL数据库及CRUD操作示例forestsea2 小时前
Java虚拟机面试题:内存管理(中)茶本无香2 小时前
Java异步编程中的CompletableFuture介绍、常见错误及最佳实践