浅拷贝 深拷贝(深浅复制)

  • 简单数据类型/基本数据类型
		// 此时 str1 中存储的是 数据 张三
        var str1 = '张三';

        // 将 str1 中存储的数据 张三 赋值给 str2 
        var str2 = str1;

        // 之后对str1 的操作,与str2,无关
        str1 = '李四';

        console.log(str1, str2);

控制台输出:
在这里插入图片描述

  • 引用数据类型/复杂数据类型
 		// arr1 变量中 存储的是 数组的 内存地址
        var arr1 = [1, 2, 3, 4, 5];

        // 将arr1 存储的内存地址,赋值给arr2,两个变量存储的是相同的内存地址
        var arr2 = arr1;

        // 数组 arr1和arr2 引用同一个堆内存 改变其中一个数组  另一个数组也会有影响
        arr1[0] = 'x';

        console.log(arr1, arr2);

控制台输出:
在这里插入图片描述
直接将一个引用数据类型的地址,赋值给另一个变量存储的,两个变量存储的是相同的内存地址,一个操作,另一个也会改变,称为浅拷贝(浅复制)

只复制引用数据类型中的数值而不是复制地址,称为 深拷贝(深复制)
需要建立一个独立的变量,复制引用数据类型中的数据内容

 	// 只复制brr1中的数据
    var brr1 = [1, 2, 3, 4, 5];

    // 循环遍历,获取brr1中的所有数据数值,赋值到新的数组中
    var brr2 = [];

    // 通过循环,生成brr1的所有索引下标
    for (var i = 0; i <= brr1.length - 1; i++) {
        
        var item = brr1[i];  
        // 获取brr1中的 存储的 数据信息1 2 3 4 5

        brr2.push(item);     
        //将brr1中的数据 brr1[i] , 写入到 brr2中
    }

    console.log(brr1, brr2, brr1 === brr2);

    brr1[0] = 'x';

    console.log(brr1, brr2);

控制台输出:
在这里插入图片描述

s总结

  • 基本数据类型

        赋值的是 存储的数据
        赋值之后 两个变量没有关系
    
  • 引用数据类型

        浅拷贝(浅复制)
           直接赋值 赋值的是 内存地址
           赋值之后 两个变量使用的相同内容,一个操作,另一个也会改变
        深拷贝(深复制)
           循环遍历,获取引用数据类型中,存储的每一个数据信息
           赋值到新的变量中
           赋值之后 两个变量,没有任何关系
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值