zoukankan      html  css  js  c++  java
  • 浅拷贝与深拷贝

    如何区分 简单来说  B复制了A  如果修改A,B也跟着变化, 这就是浅拷贝(拿人手短)。如果修改了A ,B没有变化 这是深拷贝(自食其力)

    1、基本数据类型 number string boolean null undefined symbol

         基本数据类型 名值存储在栈内存中,当b=a   直接在栈内存中开辟内存

    2、引用类型 名存储在栈内存,值存储在堆内存中,栈内存开辟个地址指向堆内存的值。

         当b=a  b和a的栈内存地址同时指向 堆内存的同一个值 

         如深拷贝b=a  b和a指向堆内存中不同的值 修改任何一个对另一个没有影响。

    简单是实现一个深拷贝

    function deepClone(obj){
        let objClone = Array.isArray(obj)?[]:{};
        if(obj && typeof obj==="object"){
            for(key in obj){
                if(obj.hasOwnProperty(key)){
                    //判断ojb子元素是否为对象,如果是,递归复制
                    if(obj[key]&&typeof obj[key] ==="object"){
                        objClone[key] = deepClone(obj[key]);
                    }else{
                        //如果不是,简单复制
                        objClone[key] = obj[key];
                    }
                }
            }
        }
        return objClone;
    }    
    let a=[1,2,3,4],
        b=deepClone(a);
    a[0]=2;
    console.log(a,b);

    期中需要注意concat方法与slice 对于对象只有一级层级的 是深拷贝 但 如果对象多于一级层级 是浅拷贝

    出了递归还可以借助 JSON.stringfy 和 JSON.parse  来实现深拷贝

    function deepClone(obj){
        let _obj = JSON.stringify(obj),
            objClone = JSON.parse(_obj);
        return objClone
    }    
    let a=[0,1,[2,3],4],
        b=deepClone(a);
    a[0]=1;
    a[2][0]=1;
    console.log(a,b);

    原理 先将对象转换成字符串 然后再转换回来

  • 相关阅读:
    Android之vector代码修改颜色
    一个关于native sql的程序
    webdynpro 下拉列表控件
    webdynpro tree控件使用
    webdynpro MESSGAE
    webdynpro的select_option示例
    一个简单的webdynpro的ALV示例
    ALV前导零的问题
    自动流水号
    OO的ALV隐藏工具栏的form
  • 原文地址:https://www.cnblogs.com/junwu/p/14066799.html
Copyright © 2011-2022 走看看