再谈深浅拷贝 后端 - 前端

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

 

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

 

end

 

转载于:https://www.cnblogs.com/crith/p/9603961.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值