ThreadLocal使用出现的问题
2017-10-21 08:55
295 查看
有三个系统A,B,C;A,B需要通过调用C的接口c1,C在接口中针对A,B传给接口的companyCode会拿到公司companyId放入到ThreadLocal,companyId作为mybatis拦截器中参数会在所有的sql操作的where条件中加上,假如C有个c2接口也会使用ThreadLocal变量,这是应该获取不到这个变量,但实际下来c2接口也会拿到值,这是为什么?
通知一个请求会是一个线程,也就说A,B调用c1会各自线程处理,c2被调用也会有自己的线程处理,ThreadLocal按理说应该取不到,因为ThreadLocal以当前线程做为Map key来存储和使用对象的,源码实现如下
取到了说明c2和c1接口共用了一个线程,这与一个请求生成一个线程相悖,后来查可能与tomcat线程池有关系,也就是c2与c1使用了tomcat线程池的同一个线程。
通知一个请求会是一个线程,也就说A,B调用c1会各自线程处理,c2被调用也会有自己的线程处理,ThreadLocal按理说应该取不到,因为ThreadLocal以当前线程做为Map key来存储和使用对象的,源码实现如下
public void set(T value) { Thread t = Thread.currentThread(); ThreadLocalMap map = getMap(t); if (map != null) map.set(this, value); else createMap(t, value); }
public T get() { Thread t = Thread.currentThread(); ThreadLocalMap map = getMap(t); if (map != null) { ThreadLocalMap.Entry e = map.getEntry(this); if (e != null) { @SuppressWarnings("unchecked") T result = (T)e.value; return result; } } return setInitialValue(); }
取到了说明c2和c1接口共用了一个线程,这与一个请求生成一个线程相悖,后来查可能与tomcat线程池有关系,也就是c2与c1使用了tomcat线程池的同一个线程。
相关文章推荐
- 使用ThreadLocal却出现了有并发问题?
- ThreadPoolExecutor 与 ThreadLocal 配合使用中出现数据不一致问题
- 初步使用ASP.net出现的怪问题
- 如何解决ADO.NET访问Access数据库出现"操作必须使用一个可更新的查询"的问题(非原创,摘自书中)
- Enterprise Library- Data Block使用oracle存储过程,字符串参数传入值为""时出现问题的解决
- Inspiration 7.6使用时出现的问题
- 使用返回 DataTable 的 XML Web 服务时出现问题
- 使用Nunit对使用NHibernate的类进行测试出现的问题解决
- Vs2003使用时出现这个问题,正在郁闷中,网上找了好久,居然看到同样问题,马上拷贝来:)开心中
- 使用Foreach时出现的一个小问题
- 关于使用VS.Net2003调试器出现的问题及相关解决方法
- 如何解决ADO.NET访问Access数据库出现"操作必须使用一个可更新的查询"的问题
- 在使用Oracle9Ii时出现的一个问题~~
- 使用hibernate心得——字符串超长的解决办法(setCharacterStream出现顺序问题)
- eclipse使用中出现的一个问题
- 关于在VB中使用Access数据库出现的问题
- TWebBrowser使用中出现的几样怪问题(BUG?)
- 使用copy出现的问题
- 关于使用 session_start 出现的 Warning: session_start(): Cannot send sessioncache limiter - 问题的解决
- 蛙蛙推荐:使用FreeTextBox出现脚本错误的问题解决