首先,要明确一点,Servlet是单实例的,这个很重要!
生命周期的流程:
创建对象-->初始化-->service()-->doXXX()-->销毁
创建对象的时机:
1,默认是第一次访问该Servlet的时候创建
2,也可以通过配置web.xml,来改变创建时机,比如在容器启动的时候去创建,DispatcherServlet(SpringMVC前端控制器)就是一个例子
<load-on-startup>1</load-on-startup>
执行的次数
对象的创建只有一次,单例
初始化一次
销毁一次
关于线程安全
构成线程不安全三个因素:
1,多线程的环境(有多个客户端,同时访问Servlet)
2,多个线程共享资源,比如一个单例对象(Servlet是单例的)
3,这个单例对象是有状态的(比如在Servlet方法中采用全局变量,并且以该变量的运算结果作为下一步操作的判断依据)
伪代码,演示线程不安全的操作方式
public class MyServlet extends HttpServlet{
private int ticket = 100;
public void doXXX(){
if(ticket > 0){
//......
ticket--;
}
}
}
所以,我们要避免在Servlet中做上述类似的操作!
分析Servlet内部源码,关于Service对请求的分发处理逻辑,会调用相应的doXXX方法