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、避免使用实例变量(最佳)

猜你喜欢

转载自lvwenwen.iteye.com/blog/1630903