一、数据类型及存储方式
要了解什么是浅拷贝与深拷贝,首先我们得了解数据类型及它们的存储方式是什么样的。
1、数据类型分类
简单数据类型(值类型):Number、String、undefined、Boolean、null等等。
复杂数据类型(引用类型):Function、Array、Object、Date、Math等。
2、存储位置
(1)栈内存
简单数据类型直接存储在栈(stack)中的简单数据段,占据空间小、大小比较稳定,属于被频繁使用数据,所以放入栈中存储;
(2)堆内存
复杂数据类型存储在堆(heap)中的对象,在栈内存中只是存了一个地址来表示对堆内存中的引用。 堆内存是无序存储,可以根据引用直接获取。每创建一个新的对象,就会在堆内存中开辟出一个新的空间,如果栈内存中的两个变量保存的是同一个对象引用,当一个通过一个变量修改属性时,另一个也会受到影响。
当解释器寻找引用值时,会首先检索其在栈中的地址,取得地址后从堆中获得实体。所以,JavaScript中对引用数据类型的操作都是操作对象的引用而不是实际的对象。可以理解为,栈内存中保存了一个地址,这个地址和堆内存中的实际值是相关联的。
二、浅拷贝与深拷贝
1、浅拷贝
只是将数据中存放的引用拷贝下来,依旧指向同一个存放地址。
现在我们举一个例子来认识一下浅拷贝:
let obj1 = {
a:2
} //创建对象obj1
let obj2 = {
a:1
} //创建对象obj2
obj2 = obj1; //将obj1赋给obj2
obj1.a