servlet、struts1的action和struts2的action初始化及线程安全模式

初始化:

servlet在容器启动时就调用init方法初始化了,当容器正常停止时调用destroy方法进行销毁。客户请求servlet时容器根据web.xml中的配置找到正确的servlet,然后响应客户请求

struts1的action在客户第一次请求时才实例化,以后用户每次请求这个action时,都使用同一个实例,struts1的Action 是在第一次请求的时候实例化的,比如第一次请求LoginAction时会创建这个Action, 之后并没有放弃这个Action实例 而是将Action实例放在一个Map 中 当你再一次请求LoginAction的时候会先从这个Map中去找,如果找到了就直接用,没找到才创建.

struts2的action在客户每次请求时都创建一个实例,请求结束后java垃圾回收机制会在适当时机将这个实例回收。

struts2 的Action 是每次请求的时候都会帮你创建一个对象, 我个人认为原因在于 struts2中的Action因为要有收集数据的javaBean的功能, 所以你会想的到,它如果是单例模式的话,会有什么危险。

线程模式:

Struts1的Action是单实例多线程模式并且必须是线程安全的,因为仅有Action的一个实例来处理所有的请求。单例策略限制了Struts1 Action能作的事,并且要在开发时特别小心。Action资源必须是线程安全的或同步的,即不能创建在方法中可以修改的action类的成员变量,它会导致成员变量的线程访问冲突,多个用户同时访问时可能会得不到正确的结果。

servlet同struts1的action一样都是单实例多线程的。

Struts2: Action对象为每一个请求产生一个实例,是多实例的,因此没有线程安全问题。

猜你喜欢

转载自blog.csdn.net/ld2007081055/article/details/16965533