既然 SessionFactory.openSession() 每次获得的都是不同的对象,那就根本不存在多线程访问冲突的问题,为什么还要搞 ThreadLocal 之类的东西来解决这个所谓的问题?
如果是这个问题,那我是这样理解的:“多线程访问冲突”的问题,并不是一开始需要解决的问题,而是为了解决另外一个问题时产生的问题。真正要解决的是“如何在程序处理过程中随时能得到一个 session 对象,用于数据库操作”。
一个 request 被 servlet 处理的过程中,会穿透很多层代码,用参数传递显然不方便,所以要能够“随时得到”,但同时又希望整个过程中得到的都是同一个 session 对象,这样才方便事务控制等要求。那么怎么办呢?“单例”和“全局变量”都可以达到这个目标,但都会产生“多线程访问冲突”的问题。于是就有了 ThreadLocal 这种类似于“全局变量”的方法。