js知识版图-引用类型赋值、浅拷贝、深拷贝

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js知识版图-引用类型赋值、浅拷贝、深拷贝相关的知识,希望对你有一定的参考价值。

参考技术A 我们先来复习下数据类型相关知识:
此处引申知识点:基本数据类型

这里所说的赋值是对象的引用赋值,当我们把一个对象赋值给一个新的变量时,赋的其实是该对象在栈中的地址,而不是堆中的数据。也就是两个对象指向的是同一个存储空间,无论哪个对象发生改变,其实都是改变的存储空间的内容,因此,两个对象是联动的。

浅拷贝是按位拷贝对象,它会创建一个新对象,这个对象有着原始对象属性值的一份精确拷贝。如果属性是基本类型,拷贝的就是基本类型的值;如果属性是内存地址(引用类型),拷贝的就是内存地址,因此如果其中一个对象改变了这个地址,就会影响到另一个对象。即默认拷贝构造函数只是对对象进行浅拷贝复制(逐个成员依次拷贝),即只复制对象空间而不复制资源。

由此可见浅拷贝只解决了第一层的问题,如果接下去的值中还有对象,两者享有相同的地址。

深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。

以上是关于js知识版图-引用类型赋值、浅拷贝、深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

赋值,浅拷贝,深拷贝

如何实现数组深拷贝和浅拷贝?

js中浅拷贝和深拷贝以及深拷贝的实现

JavaScript 的 深拷贝和浅拷贝

js实现深拷贝

js浅拷贝(地址引用)和深拷贝(克隆)