javascript 性能测试系列:函数调用

一直都认为,javascript的函数调用是一个相对耗时的操作。
开始 JSI的优化,这些问题现在必须认真考虑了,测试一把:

一个简单的++操作,直接操作和函数内操作(注,函数参数对原始类型是值传递,所以这不会影响被传入的变量,这里测试里面,两类操作的行为是不一样的)

FF2测试结果(callTime/opTime):
2871/2582
2919/2675
2734/2704
2953/2516
3732/3346

IE7测试结果:
3140/376
3173/327
3238/247
3265/235
3217/299

通过测试可见,函数调用的消耗基本可以忽略。每次调用时间仅为:
3000/(200*1000*5) ==0.3毫秒 ,这个时间还包含函数内部的++操作

从示例可见,FF的函数调用消耗基本可以府略,IE虽然相当于十倍++类简单操作,但依然不足以重视。

奇怪的是,第一次碰见ie的运行效率高于ff的情况。

测试代码
js 代码
 
  1. var i = 0;  
  2. var callTime = 0;  
  3. var opTime = 0;  
  4. var inc = 0;  
  5. function plus(z){z++};  
  6. while(inc++<200){  
  7.   var i=0;  
  8.   var x = 1;  
  9.   var t1 = new Date();  
  10.   while(i++<1000){  
  11.     plus(x);  
  12.     plus(x);  
  13.     plus(x);  
  14.     plus(x);  
  15.     plus(x);  
  16.   }  
  17.   
  18.   var t2 = new Date();  
  19.   while(i++<2000){  
  20.     x++;  
  21.     x++;  
  22.     x++;  
  23.     x++;  
  24.     x++;  
  25.   }  
  26.   var t3 = new Date();  
  27.   callTime+=(t2-t1);  
  28.   opTime+=(t3-t2);  
  29. }  
  30.   
  31. prompt("callTime/opTime",callTime +'/'+opTime)  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值