用于不同线程下存储共享的数据变量,线程开启时接收当前的共享变量,其他线程开启时也可以接收,他们之间不会影响并且该threadLocal会作用在整个线程生命之间,也就意味着无论线程执行到哪一个代码类都能获取到存储的属性,相当于线程创建的属性,可用在该线程所要执行的任何对象的方法上获取,如前端请求开启线程-》controller-》service-》dao都是线程要执行的地方,而线程开启时创建了过Threadlocal则后继的执行的类区域都能获取到线程的ThreadLocal的存储对象,而且线程与线程之间不会干扰,如在拦截器里拦截请求获取前端的参数值放入该拦截器的ThreadLocal中,在并发的时候,每个开启的线程都会执行到各自的拦截器创建各自的threadLocal,接收前端相同的变量,到线程内部时这个变量在多线程中互不干扰,同一个线程上下文可以任何类内的任何方法获取。
相关推荐
lcreek2 小时前
Java 反序列化漏洞深度解析(一):从URLDNS到真正的DNS探测杰克尼2 小时前
天机学堂复习总结(day03-day04)x***r1512 小时前
jdk-11.0.16.1_windows使用步骤详解(附JDK 11环境变量配置与验证教程)弹简特3 小时前
【Java项目-轻聊】01-项目演示+项目介绍+准备工作+项目源码luck_bor3 小时前
File类&递归作业武子康3 小时前
Java-07 深入浅出 MyBatis数据库一对多关系模型实战:表结构设计与查询实现REDcker5 小时前
Linux OverlayFS详解Royzst6 小时前
xml知识点鱼鳞_6 小时前
苍穹外卖-Day08(缓存套餐)过期动态6 小时前
【LeetCode 热题 100】移动零