js数组合并concat()和Array.prototype.push.apply()的性能分析
来源:互联网 发布:数据库原理课程设计 编辑:程序博客网 时间:2024/06/08 03:05
js数组合并有两个常用方法,用法如下:
var a=[1,2,3],b=[4,5,6];
1.a.concat(b);//得到1,2,3,4,5,6;
1.1那个数组在前面合并后那个数组的元素就在前面
1.2 可以利用这个来复制一份数组,a.concat(a);
1.3 数组长度无限制,返回值是合并后的数组
1.4 千万级别的数组合并大约30毫秒
2.Array.prototype.push.apply(a,b) or a.push.apply(a,b);
2.1.Array.prototype.push.apply(a,b) ;//a,b两个数组都变成合并后的数组
2.2 数组长度有限制,不同浏览器不同,一般不能超过十万
2.3返回值是合并后数组的长度
2.4 在一万数据左右性能和concat差不多,大约2毫秒
总结:测试结果可知,还是用concat会划算一点,看返回值也可以知道,apply方法改变两个数组,性能自然会慢,而且有局限性,在这里再扯多一句,很多人不知道什么时候用
json什么时候用数组,如果频繁添加删除的尽量用json,因为这是数组的短处,如果频繁取数据的用数组。时间有限,下次会专门来扯一扯这个话题。
共享一下测试concat()和Array.prototype.push.apply(a,b) 的代码,有需要的拿走玩玩
function testClass(){
var testArray1=[];
var testArray2=[];
this.resetArray=function(){
for(var i=0; i<10000000;i++){
testArray1.push(i);
testArray2.push(i+10000000);
}
}
this.applyTest=function(){
var startTime=0,
endTime=0;
console.log('开始合并的时间是:'+ (startTime=new Date().getTime()));
var aa=Array.prototype.push.apply(testArray1,testArray2);
console.log(aa);
console.log('合并完成的时间是:'+ (endTime=new Date().getTime()));
console.log('合并数组所用的时间是:'+(endTime-startTime));
}
this.concatTest=function(){
var startTime=0,
endTime=0;
console.log('开始合并的时间是:'+ (startTime=new Date().getTime()));
var aa= testArray1.concat(testArray2);
console.log(aa.length);
console.log('合并完成的时间是:'+ (endTime=new Date().getTime()));
console.log('合并数组所用的时间是:'+(endTime-startTime));
}
}
var apply=new testClass();
apply.resetArray();
apply.applyTest();
var concat=new testClass();
concat.resetArray();
concat.concatTest();
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- Array.prototype.push.apply(a,b)与a.concat(b) 合并解析,array.filter实例(数组去重)
- Array对象的方法实现(1)----Array.prototype.push和Array.prototype.concat(实现常规参数的功能)
- Array.prototype.push结合apply 实现 object 伪装数组
- JS 合并数组之concat
- js数组的push pop split concat join
- JS数组追加数组采用push.apply的坑
- js里面的push和concat的区别
- js--Array.prototype.slice.apply(arguments);
- JavaScript : Array.prototype.concat()中涉及嵌套数组
- Javascript数组---push(),concat()方法的区别
- JS的prototype和__proto__ apply和call
- Array.prototype.slice.apply的使用方法
- js使用数组作为参数,直接调用push与apply方法调用push的区别
- js数组的常见操作( push、pop、unshift、shift、splice、concat、 join)的用法
- Array的push与unshift方法性能分析
- less 学习记录-匹配继承
- 树莓派远程连接的三种方式总结
- MySQL数据库事务隔离级别
- Web Service调用
- 数据库迁移问题
- js数组合并concat()和Array.prototype.push.apply()的性能分析
- 动画篇-碎片动画
- Java中多线程并发体系知识点汇总
- Linux memcached 环境配置
- win7 plsql里查询出来的中文信息,复制粘贴的时候出现乱码的解决方案
- Oracle utl_file读取csv文件到数据库
- DBA必须熟悉的、最有用的DBA视图。
- 逆向分析 Android 程序- 内存内存
- 初学多线程