前端浅析深拷贝与浅拷贝的区别,以及纯手写实现深拷贝

浅析深浅拷贝的区别:
深浅拷贝简单来讲就是针对引用的数据类型而言,像Object 和Array;

浅拷贝: 只复制指向某个对象的指针,而不是复制对象本身,新旧对象共享一个内存,当对新旧对象中的某一个进行改变的时候(本质上改变的是内存中的数据), 另一个对象也会同时改变;

深拷贝:会在堆内存中复制一个一模一样的数据,新旧对象的变更,互不影响;

两者的本质区别,浅拷贝复制的是指针(即引用地址,指向同一份数据), 深拷贝复制的是原始数据;

浅拷贝的实现:

1.最简单的就是等号赋值;

2.对象Object.assign()

3.数组Array.prototype.concat()

深拷贝的实现:

1.序列化 (但是有巨坑)

 const obj={
    name:'zhangsan',
    age:22,
    sex:'male',
  }
  const newObj=JSON.parse(JSON.stringify(obj))

巨坑!!!!!

1).obj中有时间对象,序列化,反序列化之后,时间对象会变成字符串;

2).obj中有Regexp,,Error对象,序列化之后会得到一个空对像;

3).obj中如果有函数,undeine的,序列化之后 函数和undefined会丢失;

4).JSON.Stringify()只能序列化对象的可枚举自由属性, 如果Obj中的对象是有构造函数生成的,那么用序列化,反序列化进行深拷贝之后,会丢失对象的constructor.

2.递归实现

function deepCopy(obj) {
  //数组和对象返回的都是object
  if (typeof obj === 'object') {
    // 判断是数组还是对象.两个方法二选一
    const newObj = Array.isArray(obj) ? [] : {}
    // const newObj = (obj.constructor === Array): []: {}  
    for (let key in obj) {  //遍历obj,for in 方法既可以便利对象也可以遍历数组
      if (typeof obj[key] === 'object') {
        newObj[key]=deepCopy(obj[key])

      } else {
        newObj[key] = obj[key]
      }
    }
    return newObj
  } else {
    return
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值