JS面试题之浅拷贝与深拷贝

文章讲述了在JavaScript中由于对象是引用类型,直接赋值会引发共享引用的问题,从而引出对象拷贝的需求。浅拷贝只复制对象的引用,而深拷贝则会创建独立的副本。文中通过扩展运算符、for...in、Object.assign()展示了浅拷贝的实现,并用递归和JSON.stringify/parse方法解释了深拷贝的原理。同时,提到了JSON方法无法处理函数的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.为什么需要拷贝?

数据类型分为原始类型与引用类型,对象是引用类型,栈中存放对象的地址,堆中才存放真实的对象。如果使用简单的赋值运算符来复制对象,复制的只是引用,这会导致修改新的对象时,原对象也随之修改,不具备安全性。

因此为了使两个对象具有独立的空间,修改新对象不会影响原对象,我们可以采用对象拷贝来实现对象的复制。分为浅拷贝与深拷贝两种。

2.浅拷贝

如果对象中属性值的类型是原始类型,就拷贝到独立的空间中,如果是引用类型,只拷贝引用地址

使用for ..in、扩展运算符、Object.assign()实现

// 使用扩展运算符实现浅拷贝
    let a = {
      name: '小明'
    }
    let b = { ...a }
    console.log(b)
    a.name = '小红'
    console.log(b.name)

    //使用for in 实现浅拷贝
    function shallowClone (obj) {
      let newObj = {}
      for (let key in obj) {
        newObj[key] = obj[key]
      }
      return newObj
    }
    let copy = shallowClone(a)
    console.log(copy)

    //使用Object.assign()
    let copy2 = {}
    Object.assign(copy2, a)
    console.log(copy2)

3.深拷贝

使用递归实现

    let person = {
            name: '张三',
            sex: '男',
            hobby: ['打球', '游戏'],
            job: {
                salay: 20
            }
        }
    // 深拷贝与浅拷贝
    function deepClone (obj, newObj) {
            for (let key in obj) {
                if (obj[key] instanceof Array) {
                    newObj[key] = deepClone(obj[key], [])
                }
                else if (typeof obj[key] === 'obj') {
                    newObj[key] = deepClone(obj[key], {})
                }
                else {
                    newObj[key] = obj[key]
                }
            }
            return newObj
        }
     newObj = deepClone(person, {})
     console.log(newObj)

使用JSON.stringify与parse实现:

 let copy = JSON.parse(JSON.stringify(person))
 console.log(copy)

区别:JSON不能拷贝函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值