servlet线程安全性探索

文章链接:http://developer.51cto.com/art/200907/133827.htm

            http://www.yesky.com/334/1951334.shtml
在Serlet中避免使用实例变量是保证Servlet线程安全的最佳选择。从Java 内存模型也可以知道,方法中的临时变量是在栈上分配空间,
而且每个线程都有自己私有的栈空间,所以它们不会影响线程的安全。
在Serlet中避免使用实例变量是保证Servlet线程安全的最佳选择。从Java 内存模型也可以知道,方法中的临时变量是在栈上分配空间,
而且每个线程都有自己私有的栈空间,所以它们不会影响线程的安全。
(Servlet/JSP默认是以多线程模式执行的,Servlet多线程体系结构是建立在Java多线程机制之上的,它的生命周期是由Web容器负责的。当客户端第一次请求某个Servlet时,Servlet容器将会根据web.xml配置文件实例化这个Servlet类。当有新的客户端请求该Servlet时,一般不会再实例化该Servlet类,也就是有多个线程在使用这个实例。
这样,当两个或多个线程同时访问同一个Servlet时,可能会发生多个线程同时访问同一资源的情况,数据可能会变得不一致)
1.解决serlet线程安全问题
  1、实现 SingleThreadModel 接口(Servlet引擎将为每个新的请求创建一个单独的Servlet实例,
  这将引起大量的系统开销。SingleThreadModel在Servlet2.4中已不再提倡使用)
  2、同步对共享数据的操作(同样如果在程序中使用同步来保护要使用的共享的数据,也会使系统的性能大大下降)
  3、避免使用实例变量(最佳)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值