标签:
 
 
 还有个帖子来自osc:http://my.oschina.net/tangcoffee/blog/303865,压力测试jsp和beetl,证明beetl性能是JSP的2倍,如下是截取的部分数据
    采用jfinal+beetl模板,apache ab压力测试结果
  
     未采用beetl,apache ab测试结果:
  
究竟怎么回事情,使得编译执行的JSP执行比解释执行的Beetl慢。基本上来说,Beetl并没有做出超越常规的性能优化,而是JSP本身性能优化不够导致的。
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="UTF-8"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Test JSP</title>
</head>
<body>
<%
String a = "Test JSP";
%>
<%=a %>
</body>
</html>。 Tomcat7 会编译成为
out.write("<html>\r\n");
      out.write("<head>\r\n");
      out.write("<meta http-equiv=\"Content-Type\" 
            content=\"text/html; charset=ISO-8859-1\">\r\n");
      out.write("<title>Test JSP</title>\r\n");
      out.write("</head>\r\n");
      out.write("<body>\r\n");
String a = "Test JSP";
      out.write(‘\r‘);
      out.write(‘\n‘);
      out.print(a );
      out.write("\r\n");
      out.write("</body>\r\n");
      out.write("</html>"); 
可以看出,对于静态文本,JSP会多次调用out.write方法,而write方法内部,每次调用,都会做flush检测等耗时机制。因此,更好的方式应该是将静态文本合并一次性输出,应该是下面这种会更好点
// 期望JSP的样子
out.write("<html>\r\n<head>\r\n ....<body>\r\n“);
String a = "Test JSP";
out.write("\r\n“);
out.print(a );
out.write("\r\n</body>\r\n</html>"); 
  
 
public static void main(String[] args)throws Exception {
  String text = "<html>你好中文!你好中文!你好中文!</html>";
  {
   //模拟jsp
   long start = System.currentTimeMillis();
   for(int i=0;i<1000000;i++){
    byte[] bs = text.getBytes("UTF-8");
    write(bs);
   }
   long end = System.currentTimeMillis();
   System.out.println("jsp total="+(end-start));
  }
 
  {
   // 模拟beetl
   long start = System.currentTimeMillis();
   byte[] bs = text.getBytes("UTF-8");   
   for(int i=0;i<1000000;i++){   
    write(bs);
   }
   long end = System.currentTimeMillis();
   System.out.println("beetl total="+(end-start));
  }
 
 }
 
 public static void write(byte[] bs){
 
 } 
  输出是:
<c:choose>
   <c:when test="${param.newFlag== ‘1‘ || param.newFlag== ‘2‘}">  
    <th>1 or 2  <font color="Red">*</font>
   </c:when>  
</c:choose>  
 在我最初的想象里,我认为jsp至少会编译成如下代码: 
//期望JSP能编译成如下代码
if(request.getParameter("newFlag").equals("1")
   ||request.getParameter("newFlag").equals("2")){
    out.print(...)
} 
  但事实并不是这样,对于如上JSTL,编译成
// 实际上JSP编译的代码
out.write((java.lang.String) 
  org.apache.jasper.runtime.PageContextImpl.proprietaryEvaluate(
"${param.newFlag== ‘1‘ || param.newFlag== ‘2‘}", 
java.lang.String.class, 
(javax.servlet.jsp.PageContext)_jspx_page_context, null, false)); 也就是,JSP并没有如预期的预编译成java代码,而是动态解释执行了 test条件,这样,性能不差才怪呢.
标签:
原文地址:http://my.oschina.net/xiandafu/blog/475740