ThreadLocal线程本地存储------数据混乱的问题

问题描述:我的项目是java web项目,使用ThreadLocal用于存储关于用户相关性信息,但是发现有出现混乱的情况。明明不是这个用户的数据,出现在了这个用户这里。而且我还在每次请求之后的aspect切面,的finally语句块中使用ThreadLocal的remove方法来清除ThreadLocal中存储的数据。
 

上面的问题查找了很久:发现了以下
1、ThreadLocal简单说明。ThreadLocal是线程本地存储,数据主要存储在ThreadLocalMap当中,线程内变量的值是可以共享的,其他线程不能拿到该线程ThreadLocalMap中的值。而且ThreadLocalMap的生存期和线程的生存期是一样的。
2、tomcat中是使用线程池的,一次请求完了之后不会消除掉这个线程,而是又回到线程池当中可供其他请求来使用。那么即使调用remove方法也不能把数据清除掉。
 查看tomcat的相关线程池的信息。
linux服务器:tomcat的conf/server.xml  文件中

其中maxThreads表示线程池中最大的线程数,minSpareThreads表示线程池中最小的空闲线程数,maxSpareThreads表示线程池中最大的空闲线程数。   简单说来:线程池中最多有800个线程在工作,当请求数少的时候,至少有100个空闲的。

不同的服务器的配置不同,我这里只是一个demo说明。


---------------------------------接来下,重点来了ÿ

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
你好!对于多线程编程,ThreadLocal类是一个非常有用的工具。它提供了线程本地变量的机制,使得每个线程都可以独立地存储和获取自己的变量副本。这在一些场景下非常有用,下面是一些ThreadLocal类的应用技巧: 1. 线程上下文信息传递:在多线程环境中,有时需要在线程之间传递一些上下文信息,例如用户身份认证信息、语言环境等。使用ThreadLocal类可以很方便地实现这一目的,每个线程都有自己独立的上下文信息副本,互不干扰。 2. 线程安全的数据存储:在多线程环境中,如果多个线程需要共享一份数据,可以使用ThreadLocal类来维护每个线程的局部副本。这样每个线程都可以独立地修改自己的副本,而不会影响其他线程数据。 3. 避免传参:有些情况下,我们需要在多个方法之间传递某些参数,但是参数传递会增加代码复杂性。使用ThreadLocal类可以避免传参,每个方法可以直接从ThreadLocal中获取需要的参数值。 4. 事务管理:在一些事务场景中,我们可能需要在同一个线程中执行多个数据库操作,并保证这些操作在同一个数据库事务中。使用ThreadLocal类可以在线程中维护一个数据库连接对象,确保多个操作都使用同一个连接,实现事务的一致性。 需要注意的是,ThreadLocal类虽然提供了线程本地变量的机制,但并不是万能的解决方案。在使用ThreadLocal时,需要注意内存泄漏的问题,及时清理不再使用的资源。 希望以上内容对您有帮助!如需了解更多多线程编程相关内容,可以参考CSDN中张孝祥的相关文章。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值