服务器之家

服务器之家 > 正文

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

时间:2021-03-08 16:08     来源/作者: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测试。

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部