Java Servlet Programming 读书笔记 - servlet生命周期

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

servlet的生命周期一般为:

1.建立初始化servlet

2.处理从客户端的零个或多个请求

3.销毁servlet,gc回收占用内存

每个server可能在如何支持servlet上有不同的方法,但是上述servlet生命周期却是每个servlet 引擎必须遵守的规则。

实例持久化Instance Persistence:

一个servlet 实例一旦加载,就开始处理对这个servlet的所有请求,换句话说就是一个servlet只生成一个实例。这样的做法对于性能的提高很有好处,能够有效地降低系统开销,而且也能有效实现持久化(例如数据库连接,cache数据)

import Java.io.*;import javax.servlet.*;import javax.servlet.http.*;public class SimpleCounter extends HttpServlet {int count = 0;public void doGet(HttpServletRequest req, HttpServletResponse res)throws ServletException, IOException {res.setContentType("text/plain");PrintWriter out = res.getWriter();count++;out.println("Since loading, this servlet has been Accessed " +count + " times.");}}上例是一个简单的反映servlet持久化的例子,每个请求均增加本地变量count,然后打印显示。 但是上例存在多线程风险,对于访问servlet的每个请求都可以看作是一个线程对象,他们均访问同一个servlet实例,所以会出现并发问题。非凡是存在对共享变量的读写操作时(例如上例的本地变量count),这种危险性更大。

解决的办法是增加synchronized块。

PrintWriter out = res.getWriter();synchronized(this) {count++;out.println("Since loading, this servlet has been accessed " +count + " times.");}

事实上,server上对每一个servlet的注册名称都对应servlet的一个实例,用来访问servlet的请求名称决定哪个实例来处理请求,

servlet reloading

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航