JavaScript中匿名、命名函数的性能测试
我们经常通过匿名函数(Anonymous function)来写回调。
简单来讲匿名即没有名字的函数,一般都立即执行。但是它与命名函数(有名字的函数)的性能如何呢?
我们可以比较一下,我们随便找一台可以执行Shell命令的计算机来使用大量函数调用看一看二者执行消耗时间:
anonymous.js
var count = 100000000
, sum = 0
while (count--) (function() { sum++ })()
执行一下
$ time node anonymous.js
real 0m1.456s
user 0m0.015s
sys 0m0.031s
再来看看命名函数
named.js
var count = 100000000
, sum = 0
var cb = function() {
sum++
}
while (count--) cb()
执行一下
$ time node named.js
real 0m0.575s
user 0m0.000s
sys 0m0.046s
命名函数会快很多,为什么会这样呢?其实不难解释,匿名函数每次都需要重新解释回调,但是命名函数只需要解释一次,因此性能会有提升,但是测试发现这种提升是非常非常微小的,完全不必将非常顺手的一个回调单独写成另外一个变量。
另外命名函数还有两种写法:
函数表达式
var func = function() {
console.log('a')
}
函数声明
function func() {
console.log('b')
}
其实这两个一起用的话可能会有问题,如
var func = function() {
console.log('a')
}
function func() {
console.log('b')
}
//输出为: a
因此目前多使用函数表达式的形式,但函数声明的性能如何呢?
named2.js
var count = 100000000
, sum = 0
function cb() {
sum++
}
while (count--) cb()
执行一下,并比较二者
$ time node named.js
real 0m0.553s
user 0m0.000s
sys 0m0.015s
$ time node named2.js
real 0m0.529s
user 0m0.000s
sys 0m0.047s
似乎函数声明会稍微快一点点,不过快得也非常非常不明显,个人还是建议函数声明式写法。
PS: 此数据均在Windows7下使用git-base测试。
相关文章
window.close(); 关闭浏览器窗口js代码的总结介绍
下面小编就为大家带来一篇window.close(); 关闭浏览器窗口js代码的总结介绍。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-07-07JavaScript indexOf方法入门实例(计算指定字符在字符串中首次出现的位置)
这篇文章主要介绍了JavaScript indexOf方法入门实例,indexOf方法用于计算指定字符在字符串中首次出现的位置,需要的朋友可以参考下2014-10-10实例分析javascript中的call()和apply()方法
因项目需求去研究了下javascript中的call和apply方法,去百度看了几篇介绍JS中call和apply的文章,总觉得不是很好懂,这里写下我自己的理解,供网友们参考。2014-11-11javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式
在javascript学习笔记(八)中,我们主要学习了在使用javascript面向对象编程时,如何创建对象及添加对象的属性和方法。2011-04-04JavaScript 学习笔记(九)call和apply方法
两者实现的功能是完全一样的,只是参数传递方式不一样,call是将各个参数以逗号(,)隔开,而apply是将所有参数组成一个数组进行传递。2010-01-01
最新评论