用于不同线程下存储共享的数据变量,线程开启时接收当前的共享变量,其他线程开启时也可以接收,他们之间不会影响并且该threadLocal会作用在整个线程生命之间,也就意味着无论线程执行到哪一个代码类都能获取到存储的属性,相当于线程创建的属性,可用在该线程所要执行的任何对象的方法上获取,如前端请求开启线程-》controller-》service-》dao都是线程要执行的地方,而线程开启时创建了过Threadlocal则后继的执行的类区域都能获取到线程的ThreadLocal的存储对象,而且线程与线程之间不会干扰,如在拦截器里拦截请求获取前端的参数值放入该拦截器的ThreadLocal中,在并发的时候,每个开启的线程都会执行到各自的拦截器创建各自的threadLocal,接收前端相同的变量,到线程内部时这个变量在多线程中互不干扰,同一个线程上下文可以任何类内的任何方法获取。
相关推荐
皮皮林5511 小时前
IDEA 源码阅读利器,你居然还不会?卡尔特斯5 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】白鲸开源5 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录ytadpole5 小时前
Java 25 新特性 更简洁、更高效、更现代纪莫5 小时前
A公司一面:类加载的过程是怎么样的? 双亲委派的优点和缺点? 产生fullGC的情况有哪些? spring的动态代理有哪些?区别是什么? 如何排查CPU使用率过高?JavaGuide6 小时前
JDK 25(长期支持版) 发布,新特性解读!用户3721574261356 小时前
Java 轻松批量替换 Word 文档文字内容白鲸开源6 小时前
教你数分钟内创建并运行一个 DolphinScheduler Workflow!Java中文社群7 小时前
有点意思!Java8后最有用新特性排行榜!代码匠心7 小时前
从零开始学Flink:数据源