当前位置:   article > 正文

深拷贝和浅拷贝的区别及实现_深拷贝激活机制

深拷贝激活机制

前言

js分两大数据类型:

      基本数据类型:Number,String,Boolean,Undefined,Null。(栈内存)

      引用数据类型:Date,Function,RegExp等(堆内存)

注意:闭包中的变量并不保存在栈内存中,而是保存在堆内存中。如果闭包中的变量保存在了栈内存中,随着外层中的函数从调用栈中销毁,变量也会被销毁,但是如果保存在了堆内存中,内存函数仍能访问外层已销毁函数中的变量。

区别:

      深拷贝:从堆内存中开辟一个新的区域存放新对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。

                    例如:B复制了A,修改A,B的值不改变,为浅拷贝。

      浅拷贝:从栈内存中开辟一个新的区域存放新对象,新对象跟原对象共享内存,修改新对象会改到原对象。

                    例如:B复制了A,修改A,B的值也发生了改变,为深拷贝。

实现深拷贝:

方法一:

  1. // 深拷贝
  2. deepClone (obj) {
  3. const objClone = Array.isArray(obj) ? [] : {}
  4. if (obj && typeof obj === 'object') {
  5. for (const key in obj) {
  6. if (obj.hasOwnProperty(key)) {
  7. // 判断obj子元素是否为对象,如果是,递归拷贝
  8. if (obj[key] && typeof obj[key] === 'object') {
  9. objClone[key] = this.deepClone(obj[key])
  10. } else {
  11. objClone[key] = obj[key]
  12. }
  13. objClone[key] = obj[key]
  14. }
  15. }
  16. }
  17. return objClone
  18. }

方法二:

  1. // 深拷贝2
  2. deepClone2 (obj) {
  3. return JSON.parse(JSON.stringify(obj))
  4. }

方法三:

$.extend(true,object1, object2);

实现浅拷贝:

slice(),push(),unshift()等方法就是拷贝。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/68360
推荐阅读
相关标签
  

闽ICP备14008679号