常见框架单例、多例与线程安全性总结
来源:互联网 发布:淘宝刷单新规则 编辑:程序博客网 时间:2024/06/03 23:42
单例与多例问题是指,当多个用户访问某个类时,系统是为每个用户创建一个该类实例,还是整个系统无论多少用户访问,只创建一个该类实例。
线程安全问题是指,多个用户同时在访问同一个程序时,其对于某一数据的修改,会不会影响到其他用户中的该数据。若没有影响,则是线程安全的;若有可能影响,则是线程不安全的。
现在对 HttpServlet、HttpSession、SpingMVC、Struts2 中的 Action、Hibernate 中的 SessionFactory与 Session,进行总结。
(1)HttpServlet
其是单例的。即无论多少用户访问同一个业务,如 LoginServlet,Web 容器只会创建一个该 Servlet 实例。而该实例是允许多用户访问的。
若 Servlet 中包含成员变量,则每个用户对于成员变量的修改,均会影响到其他用户所看到的该变量的值,所以这时是线程不安全的。若不包含成员变量,则是线程安全的。
(2)HttpSession
其是多例的。Web 容器会为每个用户开辟一个 Session,多个用户会有多个 Session。而每个用户只能访问自己的 Session。所以,对于 Session 来说,就不存在并发访问的情况,也就不存在线程安全的问题了。所以可以说是线程安全的。
(3)SpingMVC Controller
Spring MVC Controller默认是单例的:
单例的原因有二:
1、为了性能。
2、不需要多例。
如果需要多例,则需要在Controller类上加注解 @Scope(“prototype”)
(4)Struts2 的 Action
其是多例的。对于同一个业务,例如 LoginAction,系统会为每一个用户创建一个LoginAction 的实例,并使其成员变量 username 与 password 接收用户 交的数据。同一用户只能访问自己的 Action。所以,对于 Action 来说,就不存在并发访问的情况,也就不存在线程安全的问题了。所以可以说是线程安全的。
(5)Hibernate 的 SessionFactory
其是单例的。无论多少用户访问该项目,系统只会创建一个 SessionFactory 对象,即这个对象是可以被所有用户访问的。
SessionFactory实现类中所包含的成员变量基本都是 final常量,即任何用户均不能修改。所以,也就不存在用户的修改对其他用户的影响问题了,所以是线程安全的。
(6)Hibernate 的 Session
其是多例的。系统会为每个用户创建一个 Sessio。
Session 的实现类中定义了很多的非 final 成员变量,一个事务对成员变量所做的修改,会影响到另一个事务对同一数据的访问结果,所以是线程不安全的。
- 常见框架单例、多例与线程安全性总结
- 常见框架单例&多例 与 线程安全性总结
- 常见框架中的单例、多例与线程安全性总结
- 单例中的线程不安全性
- 线程安全的单例模型的演变与Double-Check-Locking的安全性
- 线程安全的单例模型的演变与Double-Check-Locking的安全性
- 模式+线程安全性 -- Java单例对象同步问题探讨
- 单例模式的写法和线程安全性的讨论
- 如何保证单例模式在多线程中的线程安全性
- 单例模式的线程安全性问题浅析
- 线程安全(单例与多例)
- 单例模式与线程
- 单例与线程安全
- 线程-单例与多线程
- Java线程安全性总结
- Servlet 单例多线程,并发安全性
- JCIP_2_线程安全性笔记总结
- Servlet线程安全性问题总结
- 第十五周项目1—哈希表及其运算的实现
- 第十六周 验证算法--快速排序
- jquery对象的一些讨论
- 第12周项目4 - 利用遍历思想求解图问题(6)
- Listview的itemview中包含edittext控件时的解决方案
- 常见框架单例、多例与线程安全性总结
- 第十六周--直接选择排序
- 电子印章,office控件
- Android五大布局详解
- 第十六周项目1-验证算法(1)直接插入排序
- 第十五周项目4——验证希尔排序
- 第十六周-项目一 验证算法(4)
- HTTP学习笔记(五)
- 第十六周项目1(1)--验证算法之冒泡排序