美文网首页
深拷贝和浅拷贝

深拷贝和浅拷贝

作者: 前端girl吖 | 来源:发表于2018-06-12 11:19 被阅读0次

B复制A,A改变,B改变则为浅拷贝,不改变为深拷贝

基本类型 名值存储在栈内存中 -- 深拷贝

简单的来说就是,在有指针的情况下,浅拷贝只是增加了一个指针指向已经存在的内存,而深拷贝就是增加一个指针并且申请一个新的内存,使这个增加的指针指向这个新的内存,采用深拷贝的情况下,释放内存的时候就不会出现在浅拷贝时重复释放同一内存的错误!
在js中,对于非基本类型数据(普通对象或数组),浅拷贝只是拷贝了内存地址,子类属性指向父类属性的内存地址,而子类修改后父类也会被修改

基本类型复制.png

引用数据类型 名存储在栈内存中,值存在堆内存中 栈内存会提供一个引用的地址指向堆内存中的值

引用数据复制.png

法一:
通过递归实现封装一个对象({}|[])深拷贝的函数 深拷贝拷贝对象各个层级的属性

  function deepClone(obj) {
      let cloneObj  =  Array.isArray(obj)?[]:{}
      if(obj && typeof obj == "object"){
         for(let key in obj) {
               if(obj[key] && typeof obj[key] === "object"){
                    cloneObj[key] = deepClone( obj[key] )
               }else {
                   cloneObj[key] = obj[key]
                }
          }
    }
    return  cloneObj;
}
let a = [1,2,3,4]
b = deepClone(a)
a[0] = 2
console.log(a,b)
===>a:[2,2,3,4]    b:[1,2,3,4]

slice()和conca方法并不是深拷贝,元素只有一级时,可以实现深拷贝,子对象里还有对象,就无法实现

  let a = [1,2,3,4]
  b = a.slice()
  a[0] = 2;
 console.log(a,b)
===>a:[2,2,3,4]    b:[1,2,3,4]

  let a = [1,2,[2,3],4]
  b = a.slice()
  a[0] = 2;
  a[2][0] = 1
 console.log(a,b)
===>a:[2,2,[1,3],4]    b:[1,2,[1,3],4]

===>拷贝不彻底,一级属性的确不受影响,但二级属性没拷贝成功,所以不是真正的深拷贝

法二:
借用JSON对象的parse和stringify

  function deepClone(obj){
    let _obj = JSON.stringify(obj),
    objClone = JSON.parse(_obj);
    return objClone
  }    
  let a=[0,1,[2,3],4],
  b=deepClone(a);
  a[0]=1;
  a[2][0]=1;
  console.log(a,b);

法三
借用JQ的extend方法

$.extend([deep],target,object1[,objectN])
deep表示是否深拷贝,为true为深拷贝,为false,则为浅拷贝
target Object类型 目标对象,其他对象的成员属性将被附加到该对象上。
object1 objectN可选。 Object类型 第一个以及第N个被合并的对象。

  let a=[0,1,[2,3],4],
  b=$.extend(true,[],a);
  a[0]=1;
  a[2][0]=1;
console.log(a,b);

相关文章

  • iOS深拷贝(MutableCopy)与浅拷贝(Copy)的区别

    深拷贝和浅拷贝的概念 iOS中有深拷贝和浅拷贝的概念,那么何为深拷贝何为浅拷贝呢?浅拷贝:浅拷贝并不拷贝对象本身,...

  • iOS面试题-第二页

    11.深拷贝和浅拷贝的理解. 深拷贝;拷贝的内容. 浅拷贝:拷贝的指针. 深拷贝如: NSMutableDicti...

  • iOS - copy 与 mutableCopy

    一说到拷贝,就不得不提浅拷贝和深拷贝。 何谓浅拷贝?何谓深拷贝? 往简单的说: 浅拷贝:拷贝地址。 深拷贝:拷贝内...

  • JS中的深拷贝与浅拷贝

    知乎:js中的深拷贝和浅拷贝? 掘金: js 深拷贝 vs 浅拷贝 前言 首先深拷贝与浅拷贝只针对 Object,...

  • iOS--拷贝相关题

    1、什么是深拷贝什么是浅拷贝?浅拷贝和深拷贝的区别 * 浅拷贝(shallow copy):指针拷贝,对于被拷贝对...

  • copy和mutableCopy的区别

    copy和mutableCopy的区别 深拷贝和浅拷贝的区别 在OC中对象的拷贝方式有两种:深拷贝和浅拷贝.浅拷贝...

  • 2018-10-10函数基础

    深拷贝和浅拷贝 深拷贝 copy.deepcopy(对象)浅拷贝 copy.copy(对象)深拷贝: 将对象对应的...

  • Objective-C中的浅拷贝和深拷贝

    Objective-C中的浅拷贝和深拷贝 Objective-C中的浅拷贝和深拷贝

  • JavaScript的深拷贝和浅拷贝

    原文 博客原文 大纲 前言1、对深拷贝和浅拷贝的初步认识2、深拷贝和浅拷贝的区别3、浅拷贝存在的缺陷4、深拷贝的实...

  • java中的深拷贝和浅拷贝

    简单记录一下java中的深拷贝和浅拷贝,深拷贝和浅拷贝只是针对对象而言的. 1 深拷贝代码 2 浅拷贝代码 3 测...

网友评论

      本文标题:深拷贝和浅拷贝

      本文链接:https://www.haomeiwen.com/subject/dglleftx.html