用于不同线程下存储共享的数据变量,线程开启时接收当前的共享变量,其他线程开启时也可以接收,他们之间不会影响并且该threadLocal会作用在整个线程生命之间,也就意味着无论线程执行到哪一个代码类都能获取到存储的属性,相当于线程创建的属性,可用在该线程所要执行的任何对象的方法上获取,如前端请求开启线程-》controller-》service-》dao都是线程要执行的地方,而线程开启时创建了过Threadlocal则后继的执行的类区域都能获取到线程的ThreadLocal的存储对象,而且线程与线程之间不会干扰,如在拦截器里拦截请求获取前端的参数值放入该拦截器的ThreadLocal中,在并发的时候,每个开启的线程都会执行到各自的拦截器创建各自的threadLocal,接收前端相同的变量,到线程内部时这个变量在多线程中互不干扰,同一个线程上下文可以任何类内的任何方法获取。
相关推荐
Query*5 分钟前
Java 设计模式——适配器模式进阶:原理深挖、框架应用与实战扩展Sirens.15 分钟前
Java核心概念:抽象类、接口、Object类深度剖析Meteors.15 分钟前
23种设计模式——中介者模式 (Mediator Pattern)详解望获linux17 分钟前
【实时Linux实战系列】使用 u-trace 或 a-trace 进行用户态应用剖析焰火199924 分钟前
[Java]基于Spring的轻量级定时任务动态管理框架Seven9732 分钟前
Springboot 常见面试题汇总程序员阿鹏42 分钟前
49.字母异位词分组云中隐龙1 小时前
mac使用本地jdk启动elasticsearch解决elasticsearch启动时jdk损坏问题CodeLongBear1 小时前
苍穹外卖 Day12 实战总结:Apache POI 实现 Excel 报表导出全流程解析爱学习 爱分享1 小时前
mac idea 点击打开项目卡死