JavaScript中匿名、命名函数的性能测试

前端之家收集整理的这篇文章主要介绍了JavaScript中匿名、命名函数的性能测试前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我们经常通过匿名函数(Anonymous function)来写回调。

简单来讲匿名即没有名字的函数,一般都立即执行。但是它与命名函数(有名字的函数)的性能如何呢?

我们可以比较一下,我们随便找一台可以执行Shell命令的计算机来使用大量函数调用看一看二者执行消耗时间

anonymous.js

代码如下:
执行一下
代码如下:

再来看看命名函数

named.js

代码如下:

var cb = function() { sum++ }

while (count--) cb()

执行一下
代码如下:
命名函数会快很多,为什么会这样呢?其实不难解释,匿名函数每次都需要重新解释回调,但是命名函数只需要解释一次,因此性能会有提升,但是测试发现这种提升是非常非常微小的,完全不必将非常顺手的一个回调单独写成另外一个变量。

另外命名函数还有两种写法:

函数表达式

代码如下:

函数声明

代码如下:
其实这两个一起用的话可能会有问题,如
代码如下:
输出为: a
因此目前多使用函数表达式的形式,但函数声明的性能如何呢?

named2.js

代码如下:

function cb() { sum++ }

while (count--) cb()

执行一下,并比较二者

代码如下:

$ time node named2.js real 0m0.529s user 0m0.000s sys 0m0.047s

似乎函数声明会稍微快一点点,不过快得也非常非常不明显,个人还是建议函数声明式写法。

PS: 此数据均在Windows7下使用git-base测试。

猜你在找的JavaScript相关文章