js中的深浅复制(深浅拷贝、深浅克隆) 2021.11.11

什么是浅复制

--把一个变量赋值给另一个变量,基本数据类型如数字,字符串,布尔值等这些是拷贝值,引用数

据类型如对象,数组,函数等,这些拷贝的是地址。

深复制

将一个对象从内存中完整的拷贝一份出来,从堆内存中开辟一个新的区域存放新对象,且修改新对象

不会影响原对象。

 赋值、浅拷贝、深拷贝的区别:

赋值:其实赋的是该对象、数组的引用地址,也就是说两个对象是联动的,存在关系的,只要其中一个变量改变,另外一个变量就会跟着改变。

浅拷贝:重新在堆中创建内存,拷贝前后对象的基本数据类型互不影响,但拷贝前后对象的引用类型因共享同一块内存,会相互影响。

深拷贝:从堆内存中开辟一个新的区域存放新对象,对对象中的子对象进行递归拷贝,拷贝前后的两个对象互不影响。

实现浅拷贝的方式:Object.assign()

实现深拷贝的方式:

1)最笨的方法 遍历对象然后创建给另一个对象,但还要检测 有没有嵌套的引用类型,如果有 还要再遍历子对象,一层层遍历 ,直到里边都是基本数据类型,然后再去复制,所以需要递归实现深复制

2)使用JSON.parse(JSON.stringify())

 3)实际开发中无需手动实现 深浅复制,可以借助于系统方法 或者第三方库实现 ,如函数库lodash的_.cloneDeep方法

猜你喜欢

转载自blog.csdn.net/weixin_50163576/article/details/121274384
今日推荐