struts中Action线程安全问题

本文探讨了线程安全的概念及其实现方式,特别是在J2EE环境下如何确保Servlet和Struts框架中的Action类具备线程安全性。介绍了实例变量与局部变量的区别,并提供了设计线程安全Action类的具体建议。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线程安全:在多线程环境下能正确执行的代码就是线程安全的,安全的意思就是能够正确执行,程序代码执行不出错误等其他异常情况

实例变量:在堆中分配的,并被属于该实例的所有线程共享,所以不是线程安全的

局部变量:在堆栈中分配,因为每个实例都有它自己的堆栈空间,所以是线程安全的

J2EE是一个多线程的环境,服务器针对每个请求启动一个线程来处理,所以有可能会有多个线程同时访问一个Servlet实例的情况。在Struts里面也是一样的,有可能会有多个线程同时访问一个Action实例的情况,这时就会出现线程安全的问题,所以要保证Action类中的方法具有“可重入性”,即不可以在Action的方法里改变实例变量的值。

在设计Action类时应该注意:

1、不要使用实例或静态变量存储特定请求的状态信息,因为它们会在同一个操作中共享跨越请求的全局资源,引发线程安全问题

2、如果并行访问资源需要保护,访问就要进行同步(例如:synchronized关键字的使用

3、使用常量是线程安全的,因为只存在读操作

4、对构造器的访问(new 操作)是线程安全的,因为每次都创建一个实例,不会访问共享资源

5、局部变量也是线程安全的。因为没执行一个方法,都会在独立的空间创建局部变量,它不是共享资源。局部变量包括方法的参数变量。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值