Servlet的线程安全性

转:https://blog.csdn.net/qq_38989725/article/details/74078819

属性的线程安全:

ServletContext,不是线程安全的,多线程可以同时读写。使用时要注意。
HttpSession,不是线程安全的,比如用户打开多个浏览器窗口时候就会产生多个请求针对同一个session的操作。使用时要注意。
ServletRequest,线程安全的,它对应着一个request请求,所以说是线程安全的。

常用框架的线程安全性

SpringMVC,我们知道Spring的IOC容器默认管理的bean是单实例的,对于SpringMVC的Controller来说也是单实例的,所以开发的时候需要保证线程安全。

Struts1中的action也是单实例的,使用的时候会有线程安全问题。

Struts2中Action会为每一个请求产生一个实例,所以不存在线程安全问题。

注意:当使用Spring管理Struts2的Action时,需要将Action的scope设置为prototype,因为Spring IOC容器中bean默认是单例的。

DispatcherServlet的线程安全性

在应用启动的时候,就会根据web.xml中配置的有关Spring和SpringMVC的配置启动初始化,对于SpringMVC初始化的是DispatcherServlet,对于Servlet初始化只会进行一次,并且只有一个实例,所以DispatcherServlet只会存在一个。

但是当多线程同时访问DispatcherServlet的时候是线程安全的,因为DispatcherServlet中的内部属性都不会影响线程安全,所以DispatcherServlet可以忽略线程安全的问题。

虽然DispatcherServlet可以认为是线程安全的,但是SpringMVC中的Controller不是。Controller也是单例的,每个请求对应一个Controller中的方法,方法如果没有使用实例变量,可以认为是线程安全的,但是如果有实例变量就要考虑线程安全的问题了。

备注:可以考虑用ThreadLocal来保证线程安全

猜你喜欢

转载自blog.csdn.net/weixin_42861564/article/details/81590503