再谈深浅拷贝 后端

我前些年是做后端的,js也只是实现一些效果和局部更新,在后端中数据类型大部分都是强类型的,分为值类型和引用类型,正好对应我们js里的基本数据类型和复杂数据类型。从变量存储的角度来分析基本数据的数据存在了调用栈中,引用数据类型调用栈中只保存变量的名字和变量在堆中的地址,也就是指针。当我们日常的操作把一个简单类型赋值给另一个变量后,就相当于把变量的值也拷贝了一份儿,两个变量就没有关系了,而当我们将保存对象的一个变量赋值给另一个变量时,实际上复制的是这个指针,而两个变量都指向都一个对象,因此,一个对象内部属性的修改,也会影响到另外一个对象,这个时候的操作就是浅拷贝。要想达到深拷贝,不仅要对变量的值进行复制,还要开辟新的堆内存,讲变量指向一块儿新的内存区域,这个时候两个变量才能互补影响;

有了上面的一些理论后,我们就可以自己来进行相关的测试,来验证我们的分析。

end

原文地址:https://www.cnblogs.com/crith/p/9603961.html