浅拷贝深拷贝

Posted zhtian

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了浅拷贝深拷贝相关的知识,希望对你有一定的参考价值。

浅拷贝深拷贝

  • 基本数据类型在内存单元中保存的是具体值。

  • 复杂数据类型在内存单元中保存的是具体的指针

什么是浅拷贝

创建一个新对象,这个对象有着原始对象属性值的一份精确拷贝。如果属性是基本类型,拷贝的就是基本类型的值,如果属性是引用类型,拷贝的就是内存地址 ,所以如果其中一个对象改变了这个地址,就会影响到另一个对象。

浅拷贝只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存。但深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。

1

    var obj1 = { a: 10, b: 20, c: 30 };
     var obj2 = Object.assign({}, obj1);
     obj2.b = 100;
     console.log(obj1);
     // { a: 10, b: 20, c: 30 } <-- 沒被改到
     console.log(obj2);
     // { a: 10, b: 100, c: 30 }

2 Object.assign()

Object.assign是ES6的新函数。Object.assign() 方法可以把任意多个的源对象自身的可枚举属性拷贝给目标对象,然后返回目标对象。但是 Object.assign() 进行的是浅拷贝,拷贝的是对象的属性的引用,而不是对象本身。
Object.assign(target, ...sources)

   var obj1 = { a: 10, b: 20, c: 30 };
    var obj2 = Object.assign({}, obj1);
    obj2.b = 100;
    console.log(obj1);
    // { a: 10, b: 20, c: 30 } <-- 沒被改到
    console.log(obj2);
    // { a: 10, b: 100, c: 30 }
  • 深拷贝

1 对象只有一层的话可以使用上面的:Object.assign()函数

2 转成 JSON 再转回来

    var obj1 = { body: { a: 10 } };
    var obj2 = JSON.parse(JSON.stringify(obj1));
    obj2.body.a = 20;
    console.log(obj1);
    // { body: { a: 10 } } <-- 沒被改到
    console.log(obj2);
    // { body: { a: 20 } }
    console.log(obj1 === obj2);
    // false
    console.log(obj1.body === obj2.body);
// false

3 递归拷贝

   var obj = {
      name: "jack",
      messages: {
        age: 18,
        gender: ‘men‘
      },
      arr: [10, 20]
    }

    function deepCopy(currentObj, targetObj) {
      // 基本数据类型
      for(var k in currentObj) {
        if(typeof currentObj[k]!="object" || currentObj[k]=== null) {
          targetObj[k] = currentObj[k]
        } else { // 复杂数据类型
          // 复杂数据类型值有可能是对象,也有可能是数组,需要进行判断后再设置
          targetObj[k] = currentObj[k] instanceof Array ? [] : {}
          deepCopy(currentObj[k], targetObj[k])
        }
      }
    }
    var obj2 = {}
    deepCopy(obj, obj2)
    obj.name = ‘rose‘
    obj2.messages.age=100
    console.log(obj)
    console.log(obj2)

技术分享图片


以上是关于浅拷贝深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

代码学习PYTHON 深拷贝和浅拷贝

jquery怎样深拷贝一个数组

Python高级详解 深拷贝和浅拷贝

Python高级详解 深拷贝和浅拷贝

深拷贝-浅拷贝

iOS开发——深拷贝与浅拷贝详解