前端面试题11(浅谈JavaScript深拷贝与浅拷贝)

在这里插入图片描述
在JavaScript中,数据的复制可以分为浅拷贝(Shallow Copy)和深拷贝(Deep Copy)。这两种拷贝方式主要区别在于如何处理对象中的嵌套对象。下面我会详细解释这两者的概念、区别,并提供相应的实现代码。

浅拷贝

浅拷贝是指创建一个新的对象,这个新对象的属性值是原对象属性值的引用(对于原始类型如字符串、数字、布尔值等是值的拷贝,而对于对象、数组等复杂类型则是引用的拷贝)。如果原对象的某个属性是一个对象,那么浅拷贝得到的新对象对应的属性将指向原对象中该属性所指向的对象的内存地址,也就是说拷贝得到的是同一个对象的引用。

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

    const obj = { a: 1, b: { c: 2 } };
    const shallowCopy = Object.assign({}, obj);
    
  2. Spread Operator (扩展运算符)

    const obj = { a: 1, b: { c: 2 } };
    const shallowCopy = { ...obj };
    

深拷贝

深拷贝则是递归地拷贝原对象的所有层级,直到遇到不可遍历的值(如基本类型)。这意味着,无论对象的嵌套层次多深,深拷贝都会创建一个全新的对象,拥有与原对象相同内容但完全不同内存地址的副本,包括所有子对象也会被拷贝。

实现深拷贝的方法:
  1. JSON.parse() 和 JSON.stringify()
    注意这种方法对于函数、undefined、循环引用等情况不适用。

    const obj = { a: 1, b: { c: 2 } };
    const deepCopy = JSON.parse(JSON.stringify(obj));
    
  2. 递归实现
    这种方法可以处理更多复杂情况,如函数、日期对象等。

    function deepClone(obj, hash = new WeakMap()) {
      if (obj === null || typeof obj !== 'object') return obj;
      if (hash.has(obj)) return hash.get(obj);
      
      let cloneObj = new obj.constructor();
      hash.set(obj, cloneObj);
      
      for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
          cloneObj[key] = deepClone(obj[key], hash);
        }
      }
      return cloneObj;
    }
    
    const obj = { a: 1, b: { c: 2 }, d: new Date() };
    const deepCopy = deepClone(obj);
    

总结

  • 浅拷贝只拷贝一层,对于对象或数组中的嵌套对象只是拷贝了引用。
  • 深拷贝会递归拷贝所有层级,创建一个完全独立的副本。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GIS-CL

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值