zoukankan      html  css  js  c++  java
  • Struts1、Struts2的线程安全问题

    Struts 1.x和Struts 2的Action是不是线程安全的?

    Struts 1.x在第一次请求某个Action时,会创建这个Action实例。但之后再请求该Action实例时,就用之前创建好的这个Action处理,即它是单例模式。所以Struts 1.x的Action不是线程安全的。

    但是为什么我们在使用Struts 1.x开发的时候一般不用考虑线程安全问题呢?

    那是因为Struts 1.x的方法调用模式用到的参数一般都是局部变量(包括request, response,session,config,page,pageContext等,如下面的方法定义),局部变量是线程安全的,因此不存在线程安全问题。 但是要是在execute中使用了实例变量,就会存在线程安全问题。所以我们用Struts 1.x开发时尽量不要使用实例变量,如果一定要用或者有这种需要,那么我们一定要意识到使用实例变量是存在线程安全的,可以使用同步机制去处理线程安全问题。 

    public ActionForward execute (ActionMapping mapping, 
                                    ActionForm form, 
                                    HttpServletRequest request, 
                                    HttpServletResponse response)
     throws ActionException;

    注:application在整个系统内被使用,所以不是线程安全的. 

    Struts 2 Action对象为每一个请求产生一个实例,因此没有线程安全问题 。
    在Sping + Struts 2的应用中,由Spring来管理Struts 2的Action,而IoC容器管理的bean默认是单实例的

    (scope="singleton"),加上Struts 2的Action就像一个POJO一样,定义了很多的类变量,这就有线程安全问题了。解决些问题最简单的办法就是不使用单例模式(设置scope="prototype")。 

    <bean id="testAction" class="com.webapp.action.TestAction" scope="prototype">

    Servlet是线程安全的吗?

    servlet是单实例多线程运行方式,所以对象变量线程不安全,局部变量线程安全。

  • 相关阅读:
    3.2.5 复制节点:
    1.创建元素节点:
    有多少漏洞都会重来:从ElasticSearch到MongoDB和Redis
    登陆密码显示与不显示的切换
    计算机网络基础 — Linux 路由器
    作为白手起家的企业家,必经阶段你经历了几个?
    竞争越来越大,创业公司怎么才能走的越来越远?
    城市竞争太大?这有农村创业七大项目,让你远离竞争
    短视频的改革带来的风暴,网红又该何去何从?
    照着官方文档学习react
  • 原文地址:https://www.cnblogs.com/fuxinci/p/3187654.html
Copyright © 2011-2022 走看看