5、缺省Servlet
  如果某个Servlet的映射路径仅仅为一个正斜杠(/),那么这个Servlet成为当前Web应用程序的缺省Servlet。
  凡是在web.xml文件中找不到匹配的<servlet-mapping>元素的URL,它们的访问请求都将交给缺省Servlet处理,也是说,缺省Servlet用于处理所有其他Servlet都不处理的访问请求。 例如:
1  <servlet>
2     <servlet-name>ServletDemo2</servlet-name>
3     <servlet-class>gacl.servlet.study.ServletDemo2</servlet-class>
4     <load-on-startup>1</load-on-startup>
5   </servlet>
6
7   <!-- 将ServletDemo2配置成缺省Servlet -->
8   <servlet-mapping>
9     <servlet-name>ServletDemo2</servlet-name>
10     <url-pattern>/</url-pattern>
11   </servlet-mapping>
  当访问不存在的Servlet时,使用配置的默认Servlet进行处理
  6、Servlet的线程安全问题
  当多个客户端并发访问同一个Servlet时,web服务器会为每一个客户端的访问请求创建一个线程,并在这个线程上调用Servlet的service方法,因此service方法内如果访问了同一个资源的话,有可能引发线程安全问题,把i定义成全局变量,当多个线程并发访问变量i时,会存在线程安全问题了
  加锁的做法虽然解决了线程安全问题,但是编写Servlet却万万不能用这种方式处理线程安全问题,假如有9999个人同时访问这个Servlet,那么这9999个人必须按先后顺序排队轮流访问。
  针对Servlet的线程安全问题,Sun公司是提供有解决方案的:让Servlet去实现一个SingleThreadModel接口,如果某个Servlet实现了SingleThreadModel接口,那么Servlet引擎将以单线程模式来调用其service方法。
  查看Sevlet的API可以看到,SingleThreadModel接口中没有定义任何方法和常量,在Java中,把没有定义任何方法和常量的接口称之为标记接口,经常看到的一个典型的标记接口是"Serializable",这个接口也是没有定义任何方法和常量的,标记接口在Java中有什么用呢?主要作用是给某个对象打上一个标志,告诉JVM,这个对象可以做什么,比如实现了"Serializable"接口的类的对象可以被序列化,还有一个"Cloneable"接口,这个也是一个标记接口,在默认情况下,Java中的对象是不允许被克隆的,像现实生活中的人一样,不允许克隆,但是只要实现了"Cloneable"接口,那么对象可以被克隆了。
  让Servlet实现了SingleThreadModel接口,只要在Servlet类的定义中增加实现SingleThreadModel接口的声明即可。
  对于实现了SingleThreadModel接口的Servlet,Servlet引擎仍然支持对该Servlet的多线程并发访问,其采用的方式是产生多个Servlet实例对象,并发的每个线程分别调用一个独立的Servlet实例对象。
  实现SingleThreadModel接口并不能真正解决Servlet的线程安全问题,因为Servlet引擎会创建多个Servlet实例对象,而真正意义上解决多线程安全问题是指一个Servlet实例对象被多个线程同时调用的问题。事实上,在Servlet API 2.4中,已经将SingleThreadModel标记为Deprecated(过时的)
  杂记:
  java和javax都是Java的API包,java是核心包,javax的x是extension的意思,也是扩展包