[size=medium][/size]
这篇博客,是参考资料后的心得,如有雷同,证明大家都明白了,HoHo
先说线程:
最大的误区,ThreadLocal不是一个本地线程,他是在多线程中的局部变量副本,并且他存在于线程中。
Web容器中有三个周期request/Httpsession/application
其中request是客户端发出的一个请求,这个request的载体就是一个线程,实际等同于一个线程的生命周期。
看jdk实例知道,ThreadLocal是在线程中实现一个线程局部存储。
request是一个线程,而struts和spring这些东西,在request这个线程中要进行一系列的操作,需要一个全局的变量存储地,而且这个变量在不同request线程还会不同,于是就使用到了ThreadLocal。
因此ThreadLocal在正常情况下,与request是同生命周期的,当request线程结束,ThreadLocal就会等待被回收。
ThreadLocal具体怎么实现的不就再赘述,再说说web中具体的误区与应用
原本:ThreadLocal是线程局部存储,每个请求只能访问本线程中设置的变量。
如果没有web容器,每次request请求都会新创建一个新的独立的线程,当请求结束后,java虚拟机会将该ThreadLocal删除。
但是一般应用服务器都会有一个高效的线程池系统来回收已完成处理的请求线程,也就是说当某个请求被处理完后,相应线程并不会被销毁,而是被返回到线程池中以再次响应其它请求。即多个请求为一个线程。这就麻烦了。下一个用户使用的是上一个用户的TreadLocal线程,怎么办?
解决办法是在每次新用户登录,线程创建的时候,先清空该线程,然后再将数据放进去,等这次web请求结束后,再将该线程清空
具体实现需要webFilter的帮助
分享到:
相关推荐
理解ThreadLocal 理解ThreadLocal 理解ThreadLocal 理解ThreadLocal
ThreadLocal的几种误区ThreadLocal的几种误区ThreadLocal的几种误区
ThreadLocal应用示例及理解,这个写了相关的示例,可以参考一下。
正确理解ThreadLocal.pdf
ThreadLocal
ThreadLocal入门教程。 讲解了线程安全和ThreadLocal的使用的基本知识。
ThreadLocal深度理解
ThreadLocal为解决多线程程序的并发问题提供了一种新的思路。使用这个工具类可以很简洁地编写出优美的多线程程序,ThreadLocal并不是一个Thread,而是Thread的局部变量
ThreadLocal的简单理解.doc
学习ThreadLocal,了解其中的原理,以及学习其中的优点!避免坑点!!
DbUTils中用ThreadLocal类
ThreadLocal保证一个类的实例变量在各个线程中都有一份单独的拷贝, 从而不会影响其他线程中的实例变量
NULL 博文链接:https://aty.iteye.com/blog/1913734
主要介绍ThreadLocal的原理,实例分析以及注意事项
Java中ThreadLocal工具类(解决多线程程序中并发问题的一种新思路,主要为参数的拷贝问题),感兴趣的话可以查看博文,博文地址:http://blog.csdn.net/otengyue/article/details/38459327
Synchronized与ThreadLocal
java 简单的ThreadLocal示例
设计模式及ThreadLocal详细讲解资料,想要学习java或者提升自己技术的同学可以下载观看