为了在 JavaScript 中复制一个数组:以下哪个使用起来更快?
切片
方法
var dup_array = original_array.slice();
For
循环
for(var i = 0, len = original_array.length; i < len; ++i)
dup_array[i] = original_array[i];
我知道这两种方式都只做 浅拷贝:如果 original_array
包含对对象的引用,则不会克隆对象,但只会复制引用,并且因此两个数组都将引用相同的对象。
但这不是这个问题的重点。
我只问速度。
最佳答案
至少有 6 (!) 种克隆数组的方法:
- 循环
- 切片
- Array.from()
- 连接
- 扩展运算符(最快)
- map
A.map(function(e){return e;});
有一个huuuge BENCHMARKS thread ,提供以下信息:
对于 blink 浏览器
slice()
是最快的方法,concat()
有点慢,而while 循环
慢了 2.4 倍。对于其他浏览器
while 循环
是最快的方法,因为这些浏览器没有对slice
和concat
的内部优化.
2016 年 7 月仍然如此。
下面是一些简单的脚本,您可以将它们复制粘贴到浏览器的控制台中,然后运行多次以查看图片。它们输出毫秒,越低越好。
while 循环
n = 1000*1000;
start = + new Date();
a = Array(n);
b = Array(n);
i = a.length;
while(i--) b[i] = a[i];
console.log(new Date() - start);
切片
n = 1000*1000;
start = + new Date();
a = Array(n);
b = a.slice();
console.log(new Date() - start);
请注意,这些方法会克隆 Array 对象本身,但数组内容是通过引用复制的,不会被深度克隆。
origAr == clonedArr //returns false
origAr[0] == clonedArr[0] //returns true
关于javascript - 在 JavaScript 中复制数组的最快方法 - 切片与 'for' 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3978492/