threadlocal的应用场景
时间: 2023-09-12 09:03:54 浏览: 56
ThreadLocal的应用场景有多种。一种常见的应用场景是跨方法进行参数传递。在Web容器中,每个请求周期由一个线程来处理,使用ThreadLocal可以方便地在不同方法之间传递参数。比如在Spring的IOC和AOP中结合ThreadLocal使用,可以解决事务的问题。通过将数据库连接放入ThreadLocal中,当前线程执行时只需要从ThreadLocal获取数据库连接即可。在微服务领域中,链路跟踪中的traceId传递也是利用ThreadLocal实现的。
另一个应用场景是在实际系统设计中,我们通常会选择在拦截器的业务中获取并存入用户信息,然后将其存入ThreadLocal。这样,在当前线程的任何地方需要获取用户信息时,可以使用ThreadLocal的get()方法来获取。需要注意的是,在异步程序中,ThreadLocal是不可靠的。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [Java多线程编程之ThreadLocal线程范围内的共享变量](https://download.csdn.net/download/weixin_38661008/12805733)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [【并发编程学习篇】导致JVM内存泄露的ThreadLocal详解](https://blog.csdn.net/qq_42285585/article/details/119035982)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]