NodeJS中的高效深层复制

时间:2016-04-25 21:28:17

标签: javascript node.js algorithm deep-copy

我想深入复制NodeJS中的整数数组。 我尝试的第一种方法是

obj2 = JSON.parse(JSON.stringify(obj1));

然而,它是如此之慢,因为它是一个很大的阵列。

现在我正在使用

var l = obj1.length;
while (l--){
  obj2.push(obj1[l]);
}

虽然速度快得多,但我想知道是否有更好的解决方案? 谢谢大家!

4 个答案:

答案 0 :(得分:3)

如果它是一个数组,你是否只是尝试

var arr2 = arr1.slice(0);

它确实创建了一个浅拷贝,但对于只包含原始整数的数组,它应该无关紧要。

答案 1 :(得分:1)

你也可以像

一样
var arr = [1,2,3,4,5,6,7,8],
    brr = arr.map(e => e);

答案 2 :(得分:0)

如果您的数组仅包含数字(如果您的数组包含数组,它将无法工作),您可以使用不带参数的Array.prototype.slice函数

var arr1 = [1, 2, 3, 4, 5];
var arr2 = arr1.slice();

答案 3 :(得分:0)

如果你需要得到一个有序数组并保存原始数组中元素位置的信息:

0)原始数组:

var obj1 = [1, 2, 3, 100, 5, 0, 200, 30];

1)有必要保持原来的位置:

var index = Object.keys( obj1 ).sort( function(a, b) {
  return obj1[a] - obj1[b];
});

// >> ["5", "0", "1", "2", "4", "7", "3", "6"]

2)获取一个排序数组:

var obj2 = obj1.sort( function(a, b) {
  return a-b;
});

// >> [0, 1, 2, 3, 5, 30, 100, 200]

3)使用新索引' 0':

找到元素的原始位置
var originalIndex = index[0];

// >> "5"