jsp测试函数的运行速度方法_JSP编程

通常我们需要对函数进行优化,一般的做法是开始的时候获得时间,结束的时候再获得一次时间,两次时间相减就能到到花费的时间。而函数运行速度之快,基本上都是毫秒级的。

下面给出的函数就是就此准备的。

// 时间转为时间戳(毫秒)
function time2stamp(){
  var d = new Date();
  return Date.parse(d)+d.getMilliseconds();
}

用法:

var t1 = time2stamp();
// 比较各游览器的DOM运行速度。
var divs = document.getElementByTagName("div");
var t2 = time2stamp();
alert("耗时:" + (t2 - t1) + " 毫秒");

新的方法:

var time1 = new Date
// 比较各游览器的DOM运行速度。
var divs = document.getElementByTagName("div");
alert("耗时:" + (new Date - time1) + " 毫秒");

测试各种循环的效率,for...in这样慢的循环就不测了!

<!doctype html>
<html dir="ltr" lang="zh-CN">
 <head>
  <meta charset="utf-8"/>
  <title>类</title>
  <script type="text/javascript" charset="utf-8">
   window.onload = function(){

    for (var i=0, elm; i<4000; i++) {
     elm = document.createElement("div");
     elm.innerHTML = "第一重div<div>第二重div<div>第三重div</div></div>";
     document.body.appendChild(elm);
    }
    document.getElementById("start-test").onclick = startTest;
    var uuid = 0;
    function startTest() {
     var divs = document.getElementsByTagName("div");

     var time1 = new Date();
     var i = -1, n = divs.length;while (++i < n) {
       divs[i].uuid = uuid++;
     }
     document.getElementById("time-1").innerHTML = new Date() - time1;

     var time2 = new Date();
     var i = divs.length; while (--i >= 0) {
      divs[i].uuid = uuid++;
     }

     document.getElementById("time-2").innerHTML = new Date() - time2;

     var time3 = new Date();
     for (var i=0, n=divs.length; i<n; i++) {
       divs[i].uuid = uuid++;
     }
     document.getElementById("time-3").innerHTML = new Date() - time3;

     var time4 = new Date();
     for (var n = divs.length - 1; n >= 0; n--) {
        divs[n].uuid = uuid++;
      }
     document.getElementById("time-4").innerHTML = new Date() - time4;

     var time5 = new Date();
     for (var n = divs.length - 1; n--;) {
        divs[n].uuid = uuid++;
      }
     document.getElementById("time-5").innerHTML = new Date() - time5;

     var time6 = new Date();
     var n = divs.length-1; do {
       divs[n].uuid = uuid++;
     } while (n--);
     document.getElementById("time-6").innerHTML = new Date() - time6;

     var time7 = new Date();
     for(var i=0,el;el = divs[i++];){
      el.uuid = uuid++;
     };
     document.getElementById("time-7").innerHTML = new Date() - time7;

    }
   }
  </script>
 </head>
 <body>
  <style>
   h2 {
    margin:0;
    padding:10px;
    font-weight:500;
    font-size:13px;
    background:#8080C0;
    color:#fff;
   }
   p {
    margin:0;
    text-indent:2em;
    border-bottom:2px solid #a9ea00;
    background:#F2F1D7;
   }
   span.red{
    color:red;
   }
  </style>
  <h1>JavaScript loop speed test</h1>
  <ul>
   <li>遍历页面上12000个DIV</li>
  </ul>
  <input id="start-test" type="button" value="Start test">
  <h2>循环1: var i = -1, n = divs.length;while (++i < n) { }<span class="red">顺序</span></h2>
  <p id="time-1"></p>

  <h2>循环2:var n = divs.length; while (--n >= 0) { }<span class="red">倒序</span></h2>
  <p id="time-2"></p>

  <h2>循环3:for (var i=0, n=divs.length; i<n; i++)<span class="red">顺序</span></h2>
  <p id="time-3"></p>

  <h2>循环4:for (var n = divs.length - 1; n >= 0; n--) { }<span class="red">倒序</span></h2>
  <p id="time-4"></p>

  <h2>循环5:for (var n = divs.length - 1; n--;) { }<span class="red">倒序</span></h2>
  <p id="time-5"></p>

  <h2>循环6: var n = divs.length-1; do { } while (n--)<span class="red">倒序</span></h2>
  <p id="time-6"></p>

  <h2>循环7: for(var i=0,el;el = divs[i++];){ } <span class="red">顺序</span></h2>
  <p id="time-7"></p>
 </body>
</html>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索javascript
函数
编程语言运行速度排行、编程语言运行速度、优化jsp运行速度、电脑运行速度测试、怎么测试电脑运行速度,以便于您获取更多的相关知识。

时间: 2024-11-09 04:48:41

jsp测试函数的运行速度方法_JSP编程的相关文章

jsp倒计时简单实现方法_JSP编程

本文实例讲述了jsp倒计时简单实现方法.分享给大家供大家参考,具体如下: <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% //当前时间毫秒数 Long current_time1=System.currentTimeMillis(); //结束时间毫秒数 Long end_time2=1337875200000l; //计算时间差 L

分享JSP中文乱码解决方法_JSP编程

一.JSP页面中文乱码 在JSP页面中,中文显示乱码有两种情况:一种是HTML中的中文乱码,另一种是在JSP中动态输出的中文乱码. 先看一个JSP程序: <%@ page language="java" import="java.util.*" %> <html> <head> <title>中文显示示例</title> </head> <body> 这是一个中文显示示例: <

JSP Filter的应用方法_JSP编程

Servlet有一个很有意思也很有用的功能,就是Filter. 所谓Filter,就是在用户请求到达 Servlet 之前.或者 Servlet 执行之后, 执行的一段小程序,这段程序可以对用户请求做预处理, 或者对Servlet返回的结果进行一些公用处理.Filter可以在请求到达 Servlet 之前执行, 甚至即使请求一个静态页面或图片等,Filter也会被优先执行. 这样我们可以通过Filter对应用程序内的所有对象(包括Java程序和静态内容)进行预处理. (这个功能恐怕PHP程序就无

JSP验证码动态生成方法_JSP编程

在登录应用中,为防止恶意登录,常常需要服务器动态生成验证码并存储在session作用范围中,最后以图像形式返回给客户端显示 下边的代码实现的功能:写一个JSP页,动态生成一个验证码,存储在session作用范围内,并以图像形式返回给客户端显示. 另写一个JSP页面,引用此JSP页面生成的验证码: authen.jsp代码如下: <%@ page import="java.awt.*,java.awt.image.*,java.util.*,com.sun.image.codec.jpeg.

jsp项目中更改tomcat的默认index.jsp访问路径的方法_JSP编程

jsp的工程下有一个叫做WEB-INF文件夹下的web.xml打开它 如果你要该的默认访问对象再 WebRoot 下面,就 复制代码 代码如下: <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> jsp项目默认访问的是index.jsp的页面的内容 如果想改变的话,只要改变这个名字即可,换成你需要的页面

JSP文件下载功能的4种方法_JSP编程

对于网站来说,网站本身常常需要提供一些资源或者资料进行下载,说到下载莫过于最原始的方法就是在网页上提供下载的网址.今天讲述的还有另外的几种实现文件下载的方法,对于哪种方法更好这也是看自己的需求. 1.最直接最简单的,方式是把文件地址直接放到html页面的一个链接中.这样做的缺点是把文件在服务器上的路径暴露了,并且还无法对文件下载进行其它的控制(如权限).这个就不写示例了.  2.在服务器端把文件转换成输出流,写入到response,以response把文件带到浏览器,由浏览器来提示用户是否愿意保

jsp页面 列表 展示 ajax异步实现方法_JSP编程

1. 服务端先返回页面基本结构(如message.jsp), <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%@ tag

jsp中为表格添加水平滚动条的实现方法_JSP编程

首先,本项目中使用的是bootstrap框架,因此有些人会说,给表格设置自适应属性就可以了 这里要申明的是 bootsrtap自适应是针对当浏览器不占满整个屏幕,而是一半的时候才会出现横向的滚动条 而当我们将浏览器最大化的时候,如果列数增多了呢?会出现什么效果 答案就是会出现挤压的效果,横向并不会出现滚动条 查看网上的教程,很多人都说将什么父div设置100%,table添加scrool属性均不可 这里,解决的方法很简单,设置<th>标签的属性即可,让其不要自动换行 $(document).r

JSP基本语句用法总结_JSP编程

本文实例讲述了JSP基本语句用法.分享给大家供大家参考.具体如下: 1>JSP指令 JSP指令(Directive)作用是与JSP引擎进行沟通,为JSP页面设置全局变量,声 明类以及JSP要实现的方法和输出内容的类型等 JSP指令在整个页面范围内有效,且不在客户端产生任何输出 格式:<%@ directivename attribute="value"%> <%@ directivename attribute1="value1"......