最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JS往数组中添加项性能分析_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:34:40
文档

JS往数组中添加项性能分析_javascript技巧

JS往数组中添加项性能分析_javascript技巧:比较了4种可以向数组添加项的方法之间的性能: 使用索引器添加 代码如下: console.time(index); var a = []; for (var i = 0, l = times; i a[i] = i; } console.timeEnd(index); 使用push方法 代码如下: consol
推荐度:
导读JS往数组中添加项性能分析_javascript技巧:比较了4种可以向数组添加项的方法之间的性能: 使用索引器添加 代码如下: console.time(index); var a = []; for (var i = 0, l = times; i a[i] = i; } console.timeEnd(index); 使用push方法 代码如下: consol


比较了4种可以向数组添加项的方法之间的性能:

使用索引器添加

代码如下:
console.time("index");
var a = [];
for (var i = 0, l = times; i < l; i++) {
a[i] = i;
}
console.timeEnd("index");

使用push方法

代码如下:
console.time("push");
var a = [];
for (var i = 0, l = times; i < l; i++) {
a.push(i);
}
console.timeEnd("push");

使用concat方法

代码如下:
console.time("concat");
var a = [];
for (var i = 0, l = times; i < l; i++) {
a.concat(i);
}
console.timeEnd("concat");

使用concat方法,参数为数组

代码如下:
console.time("concat with array");
var a = [];
for (var i = 0, l = times; i < l; i++) {
a.concat([i]);
}
console.timeEnd("concat with array");

把times设置为10000(万)次:

代码如下:
index: 0.310ms
push: 1.476ms
concat: 8.911ms
concat with array: 2.261ms

把times设置为100000(十万)次:

代码如下:
index: 1.967ms
push: 11.980ms
concat: 70.410ms
concat with array: 28.292ms

把times设置为1000000(百万)次:

代码如下:
index: 138.559ms
push: 93.074ms
concat: 608.768ms
concat with array: 243.371ms

把times设置为10000000(千万)次:

代码如下:
index: 1473.733ms
push: 611.636ms
concat: 6058.528ms
concat with array: 2431.6ms

总结

该结论仅受用与chrome浏览器

concat方法的执行效率是最慢的
相比两种concat方法的传参,当接受参数为数组时,执行效率要高于接受参数为非数组
索引器多数情况下执行效率要高于push方法
当执行次数越来越多时,索引器的执行效率开始不如push方法

浏览器对比

感谢网友指出,本人经验不足,在这里补上浏览器之间的横向对比

首先是使用concat方法,在ie和firefox中,参数为数组执行效率反而别参数为非数组慢一点,但差异并不大
然后index和push的方法比concat快是肯定的了,在ie中使用index方法始终要比push快,在firefox中push略胜一筹但差异不大
比较3个浏览器之间index和push方法的执行效率差异是巨大的,firefox的执行效率要比ie和chrome高出不少,在百万次的情况下,基本快10倍,ie相比另外两者最慢

以下为百万次的结果:

代码如下:
// firefox
index: timer started
index: 229.79ms
push: timer started
push: 205.12ms
concat: timer started
concat: 2136.99ms
concat with array: timer started
concat with array: 2365.18ms
```

代码如下:
// ie
index: 2,533.744 毫秒
push: 3,865.979 毫秒
concat: 4,303.139 毫秒
concat with array: 4,792.208 毫秒

本文仅仅是探讨JS的性能,通过对比加深小伙伴们对javascript的理解,希望大家能够喜欢。

文档

JS往数组中添加项性能分析_javascript技巧

JS往数组中添加项性能分析_javascript技巧:比较了4种可以向数组添加项的方法之间的性能: 使用索引器添加 代码如下: console.time(index); var a = []; for (var i = 0, l = times; i a[i] = i; } console.timeEnd(index); 使用push方法 代码如下: consol
推荐度:
标签: js javascript 性能
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top