拷贝的定义
- 拷贝:复制、Ctrl+C、搞一份一样的东西出来。
- 深拷贝:开辟一个新的空间,将原来的东西复制一份完完整整的进去,就和备份类似,所以深拷贝修改一个对象不会影响另一个对象(深拷贝是在 堆 中申请新的空间来存储拷贝的数据,这样就可以避免指针悬挂;指针悬挂:指针指向非法的内存地址,也叫野指针,也就是正常使用的指针)
- 浅拷贝:浅拷贝分为两种:
- 如果属性为基本类型的拷贝,那么复制出来的就是基本类型的值;
- 如果属性为引用类型的拷贝,那么复制的就是内存地址;
所以不管是拷贝还是被拷贝的一方改变了这个地址,都会影响到另一方
基本类型和引用类型
JS里面的几种(数据)类型分为:基本(数据)类型和引用(数据)类型;
- 基本(数据)类型:Number、String、Boolean、Null、undefined、Symbol等基本上都存放在栈中。。
- 引用(数据)类型:也就是Object type,比如Object、Array、Function、Data等,只有值存放在栈中,其他基本存放在堆中。
简单说一下什么是堆什么是栈
- 堆和栈都是操作系统自带的一个内存空间;
- 栈是有系统自动分配的内存空间,栈空间里面存储的是可以直接访问的;
- 堆是后期程序员可以开辟扩大的,一般由程序员主动分配才释放;
- 栈优点:速度快;堆优点:内存大;
你在什么时候使用过深拷贝/浅拷贝呢?
- 深拷贝:一般ES6里的新增语法都是深拷贝,深拷贝会找到复杂数据类型里面的元素的值来复制,比如说:递归、JSON(JSON.stringfy+JSON.parse)、lodash、、jQuery.extend()方法第一个参数要传true、structuredClone
- 浅拷贝:复制在内存中的引用地址,比如:剩余运算符、Object.assign()、数组原型上的方法实现数组浅拷贝(Array.prototype.slice、Array.prototype.concat)