【js基础】深拷贝和浅拷贝的区别,实现深拷贝的几种方法及优缺点

一.内存中的栈和堆:

栈(stack):1.只存放简单数据类型(Undefined,String,Boolean,Null,Number),和复杂数据类型的引用。

                  2.会自动分配内存空间,会自动释放。

堆(heap):1.存放复杂数据类型。

                  2.动态分配的内存,大小不定也不会自动释放。

二、浅拷贝和深拷贝的区别

1.浅拷贝:是只复制了该复杂数据存储在栈内存中的地址(引用),而不是在内存中重新开辟一个新的存储空间用于存储新的对象。

 var a={}

var b=a; 

//这种方式就是b浅拷贝a,若b对象属性发生改变,a对象也改变,实质上就是因为他们指向的是同一个堆内存中的对象

2.深拷贝:在堆内存中开辟一个新的存储空间,完完全全的拷贝一整个一模一样的对象

三、实现深拷贝的几种方法

1.JSON格式拷贝

  • 缺点: 1.bigint类型无法转换

                   2.undefined,symbol,function类型会丢失对应的属性

                  3.error,regexp的属性值会序列化变成空对象

                  4.date类型会被转成字符串类型

                  5.obj里有NaN、Infinity和-Infinity,则序列化的结果会变成null;

 

const obj={
  name:"",
  number:NaN,
  date: [new Date(1536626600000), new Date(1540046600000)],
}
console.log("oldobj",obj)
let str=JSON.stringify(obj)
let newobj=JSON.parse(str)
console.log("newobj",newobj)

2.扩展运算符拷贝

  • 缺点:只有一级属性为深拷贝,二级属性之后都为浅拷贝
    let newobj={...obj}

 3.手写深拷贝

function copy(obj,hash=new WeakMap()){
  if(obj == null){return} 
  if(obj instanceof Date){return new Date(obj)} 
  if(obj instanceof RegExp){return new RegExp(obj)} 
   //将以上几种特殊类型直接copy返回
  if(hash.has(obj)){
    return hash.get(obj) //查表,存在就不重复拷贝,解决循环冗余
  }
  let newobj={}
   //递归拷贝并存表
  hash.set(obj,newobj)
  for(let i in obj)
    {
      if(obj[i] instanceof Object)
      {
        newobj[i]=copy(obj[i],hash)
      }else{
        newobj[i]=obj[i]
      }
    }
  return newobj

}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值