深拷贝、浅拷贝

浅拷贝拷贝的是指针,深拷贝拷贝的是地址

1.浅拷贝

改变其中一个变量另一个变量也会跟着改变

2.深拷贝

改变其中一个变量,另一个变量不会跟着改变

常用的深拷贝的方法

1  ...扩展运算符     只能实现单一层次(第一层次)

2  JSON.parse(JSON.stringify(obj)) 

原因:先将数据转为字符串存储在栈中,再反序列化转为对象形式在堆中重新存储一份,与原数据存储地址不同

缺点:数据里的undefined和函数不能解析,性能比较低

使用如上对象obj:

3. assign(合并)

4. 递归函数

<script>

        let obj = {
            num: 0,
            o: {
                n: 0,
                o: {
                    n: 0
                }
            }
        }
        let obj1 = {}
        function fn(obj, obj1) {
            for (let key in obj) {

                if (typeof obj[key] == 'object') {
                    obj1[key] = {}
                    fn(obj[key], obj1[key])
                } else {
                    obj1[key] = obj[key]
                }

            }
        }
        fn(obj, obj1)
        obj.num = 10
        console.log(obj1)  // {num:0,o:{n:0,o:{n:0}}}

        // fn(obj,{})  for *1
        // num     obj1:{num:0}
        // o       obj1:{num:0,o:{}}

        // fn(obj.o,obj1.o) obj1.o={}  for *2
        // n  obj1.o={n:0}
        // o  obj1.o={n:0,o:{}}
        
        // fn(obj.o.o,obj1.o.o) obj1.o.o={}  for *3
        // n  obj1.o.o={n:0}


</script>

5.vue2项目中,对象没有要操作的属性,通过this.对象名.操作的属性=值,视图不会更新,但是对象里的数据已经发生改变。

由于Object.defineProperty只会监听对象中已有的属性,通过this.$set()可以将对象中的数据强制改变,视图更新。

<template>
  <div class="home">
    {{ obj }}
    <button @click="add">++</button>
  </div>
</template>

<script>

export default {
  name: 'HomeView',
  data() {
    return {
      obj: {}
    }
  },
  methods: {
    add() {
      this.obj.num = 100       // 不会更新视图
      this.$set(this.obj, 'num', 100)      // 会更新视图
      console.log(this.obj);           // 数据发生改变
    }
  }
}
</script>

包装类的深拷贝浅拷贝是指在复制一个包装类对象时,对于其中的字段如何进行复制的过程。 浅拷贝是指只复制值类型字段的值,而对于引用类型字段,只复制其引用。也就是说,新创建的对象和原始对象会共享一部分内存空间,导致对其中一个对象进行修改会影响到另一个对象。 深拷贝是指除了复制值类型字段的值外,还会对引用类型字段所指向的对象进行一次完全的拷贝。也就是说,新创建的对象会有自己独立的一份内存空间,对其中一个对象进行修改不会影响到另一个对象。 实现深拷贝的方法有多种。其中一种常用的方法是利用反序列化技术,通过将对象序列化为字节流,然后再将字节流反序列化为一个全新的对象。这种方法可以解决多层套娃式的深拷贝问题,并且效果非常好。 另外一种实现深拷贝的方式是通过覆写对象的clone()方法,实现引用对象的深度遍历式拷贝。这种方式需要对clone()方法进行重写,以便对引用对象进行递归拷贝。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [【Java】深拷贝浅拷贝(Java实现)](https://blog.csdn.net/hhb442/article/details/128801265)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值