容器中servlet是单实例,处理Http请求是多并发的。
当我们手动操作时,后台打印的线程是同一个对象。很容易误导我们。
容器管理的一个线程池,线程的再利用。手动操作速度太慢,看起来像是单线程操作,这个想法是错误的。
使用JMeter并发测试工具,创建50个线程请求一个Servlet,输出结果如下:
Current Thread: Thread[http-8081-17,5,main]
Login username: 中文
Current Thread: Thread[http-8081-3,5,main]
Login username: 中文
Current Thread: Thread[http-8081-14,5,main]
Login username: 中文
Current Thread: Thread[http-8081-40,5,main]
Login username: 中文
Current Thread: Thread[http-8081-32,5,main]
Login username: 中文
Current Thread: Thread[http-8081-17,5,main]
Login username: 中文
Current Thread: Thread[http-8081-40,5,main]
Login username: 中文
doPost()代码:
/**
* 验证是否一个请求新建一个线程,还是重用之前的线程
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
Thread t = Thread.currentThread();
System.out.println("Current Thread: " + t);
String name = request.getParameter("name");
if (name != null && !"".equals(name)) {
// 处理中文乱码
name = new String(name.getBytes("iso-8859-1"));
// get请求,参数放在url中,前台进行两次编码,后台一次解码,Tomcat会帮我们解码一次
//name = URLDecoder.decode(name, "utf-8");
System.out.println("Login username: " + name);
}
}