为什么原生的servlet是线程不安全的而Struts2是线程安全的?

Posted 关键步就几步

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么原生的servlet是线程不安全的而Struts2是线程安全的?相关的知识,希望对你有一定的参考价值。

因为原生的servlet在整个application生命周期中,只在初次访问的时候实例化一次,以后都不会再实例化,只会调用Server方法进行响应,所以如果在servlet类中定义成员变量,那么就会让每个访问的用户的都共享了此成员变量数据,既然是共享,那么任何一个人修改都会造成其他人数据的改变,所以servlet年代,成员变量是不能作为参数存放的,只能在具体每个线程访问的方法中单独获取方法定义变量接收才能保证线程安全,而Struts2是每次request访问时都会实例化一次对应action,当前的action和request线程是绑定的,所以每次访问都有对应的独立Action类,保证了Action的线程安全,那么当然可以在定义成员属性变量中定义参数接收了,所以也可以得出Action的生命周期也就是一次request请求时间,而servlet的生命周期是整个application期间

以上是关于为什么原生的servlet是线程不安全的而Struts2是线程安全的?的主要内容,如果未能解决你的问题,请参考以下文章

Servlet是线程安全吗?

Java面试题:Servlet是线程安全的吗?

Servlet的线程安全

dao 作为 servlet 的成员 - 正常吗?

Servlet不是线程安全的。

Servlet的多线程和线程安全