1

即使我在函数内处理克隆,嵌套数组也会更改。a保存数组的最有效方法是什么?JSBin 在这里

var a = [[2,3],[1,5,2],[3,7,2]];
function c(a) {
  var l = a.slice(0);
  console.log('in func, before change',l);
  l[1].splice(1,1);
  console.log('in func, after change',l);
}
console.log('before call', a);
c(a);
console.log('after call',a);
4

2 回答 2

0

.slice 不会进行“深度”复制。由于“a”的每个元素都是一个数组,iteslf,“a”的元素是对那些内部的,否则是匿名元素的引用。

数组“l”保存引用的副本,复制的引用仍然指向它们所引用的相同“对象”。

于 2013-07-29T15:10:27.260 回答
0

您的代码在一维数组上工作得很好:

function c(a) {
  var l = a.slice(0);
  console.log('in func, before change',l);
  l[1] = 17;
  console.log('in func, after change',l);
}

var a = [2,3,1,5,2,3,7,2];
console.log('before call', a);
c(a);
console.log('after call',a);

输出:

"调用前" [2, 3, 1, 5, 2, 3, 7, 2] "在函数中,更改前" [2, 3, 1, 5, 2, 3, 7, 2] "在函数中, 之后更改” [2, 17, 1, 5, 2, 3, 7, 2] “通话后” [2, 3, 1, 5, 2, 3, 7, 2]

事实上,它是一个 2D 阵列正在吸引你。查看克隆 2D javascript 数组的堆栈溢出响应:

使用 javascript 进行多维数组克隆

现在使用此代码:

Array.prototype.clone = function() {
    var arr = this.slice(0);
   for( var i = 0; i < this.length; i++ ) {
        if( this[i].clone ) {
            //recursion
            arr[i] = this[i].clone();
        }
    }
    return arr;
}

function c(a) {
  var l = a.clone();
  console.log('in func, before change',l);
  l[1].splice(1,1);
  console.log('in func, after change',l);
}

var a = [[2,3],[1,5,2],[3,7,2]];
console.log('before call', a);
c(a);
console.log('after call',a);

输出:

"调用前" [[2, 3], [1, 5, 2], [3, 7, 2]] "在函数中,更改前" [[2, 3], [1, 5, 2], [ 3, 7, 2]] "in func, after change" [[2, 3], [1, 2], [3, 7, 2]] "调用后" [[2, 3], [1, 5 , 2], [3, 7, 2]]

于 2013-07-29T15:25:58.887 回答