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

  这篇文章主要介绍了JS往数组中添加项性能分析的相关资料,需要的朋友可以参考下

  比较了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.689ms

  总结

  该结论仅受用与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的理解,希望大家能够喜欢。

 

时间: 2024-08-03 01:17:19

JS往数组中添加项性能分析的相关文章

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

比较了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

js 删除数组中重复项的几种方法

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.111cn.net/1999/xhtml"> <head> <meta http-equiv="conte

JS简单去除数组中重复项的方法_javascript技巧

本文实例讲述了JS简单去除数组中重复项的方法.分享给大家供大家参考,具体如下: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <script> var arr = ["aaa","bb

js 声明数组和向数组中添加对象变量的简单实例_javascript技巧

数组有四种定义的方式 使用构造函数: var a = new Array(); var b = new Array(10); var c = new Array("first", "second", "third"); 或者数组直接量: var d = ["first", "second", "third"]; 扩展: function ObjStory(id,biaoti,author

javascript 删除数组中重复项(uniq)_javascript技巧

可以直接使用的代码:修正版 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 下面是进阶教程与说明,喜欢跟深入的朋友可以参考下.首先让我们看下 YUI 是如何处理的: 复制代码 代码如下: var toObject = function(a) { var o = {}; for (var i = 0; i < a.length; i = i+1) { o[a[i]] = true; } return o; }; var keys = function(o) { var a=[], i;

ios-在数组中添加对象出现错误╯□╰

问题描述 在数组中添加对象出现错误╯□╰ 在往数组中添加对象时报错:-[__NSArrayI addObjectsFromArray:]: unrecognized selector sent to instance 0xa0c5f70 代码: id max; NSMutableArray * MovePointsArray=[[NSMutableArray alloc]init]; max=[pointsArray objectAtIndex:0]; for(int i=0;i<[points

java-在排序好的数组中添加一个数字,将添加后的数字插入到数组合适的位置

问题描述 在排序好的数组中添加一个数字,将添加后的数字插入到数组合适的位置 在排序好的数组中添加一个数字,将添加后的数字插入到数组合适的位置 我不会啊,求大神解答,怎么样能把一个数字插入到数组中啊,用JAVA解决 谢谢各位大神了 解决方案 http://m.blog.csdn.net/blog/Jerome_s/33316893 解决方案二: http://zhidao.baidu.com/link?url=tNCz0muJx4_ET9hG-UiYD5vdufAkzKFNvpJyVYI7b3kL

ios-在数组中添加字符串对象

问题描述 在数组中添加字符串对象 在给NSMutableArray添加元素的时候,在第四行出现错误: -[__NSArrayI addObject:]: unrecognized selector sent to instance 0x897b320 代码: NSMutableArray *mystr = [[NSMutableArray alloc] init]; mystr = [NSArray arrayWithObjects:@"hello",@"world"

c# 向数组中添加数据?

问题描述 假如一个数组string[]a={"a","b","c"}我想向这个数组中添加数据怎么弄?比如变成string[]a={"a","b","c","d"}不能直接改,要用输入的办法.新手求助! 解决方案 解决方案二:那就不用数组,用List<string>,最后都加完了再ToArray()解决方案三:string[]a=newstring[]{&q