美文网首页
浅拷贝和深拷贝

浅拷贝和深拷贝

作者: 头发飘逸 | 来源:发表于2020-03-14 23:07 被阅读0次

首先我们来说下区别:

浅拷贝只是拷贝一层, 更深层次对象级别的只拷贝引用
深拷贝拷贝多层, 每一级别的数据都会拷贝

那么我们来用代码分别实现浅拷贝与深拷贝

浅拷贝

例1:

var obj = {
    id: 1,
    name: 'andy',
    msg: {
        age: 18
    }
};
var o = {};
for (var k in obj) {
    // k 是属性名   obj[k] 属性值
    o[k] = obj[k];
}
console.log(o)

这是ES6之前的写法,Object.assign(target, ...sources) es6 新增方法可以浅拷贝
例2:

var obj = {
    id: 1,
    name: 'andy',
    msg: {
        age: 18
    }
};
var o = {};
Object.assign(o, obj); // 一行代码完美解决  
// 注: 这里第一个参数是所需要接收拷贝的对象,后面的参数是被拷贝的对象
深拷贝

例1:用递归实现深拷贝

let obj = {
    name:'张三',
    age:22,
    arr:['1',2],
    arrObj:{
        name:'李四',
        sex:'女'
    }
}

let objs = {}; // 创建一个对象用于接收

// 封装函数 第一个参数:拷贝方 第二个参数被拷贝方
function deepCopy(obj1,obj2){
    for (let v in obj2) {
        // 我们需要判断属性值属于哪种数据类型
        
        let item = obj2[v]; // 获取属性值

        if(item instanceof Array){ // 判断这个值是否是数组
            obj1[v] = []; // 拷贝方新建空数组
            deepCopy(obj1[v],item)
        }
        else if(item instanceof Object){ // 判断这个值是否是对象
            obj1[v] = {}; // 拷贝方新建空对象
            deepCopy(obj1[v],item);
        }
        else{
            // 属于简单数据类型
            obj1[v] = item;
        }
    }
}
deepCopy(objs,obj) //调用
console.log(objs)

例2:JSON.parse(JSON.stringify()) 这种方式我觉得算是最简单的

let obj1 = {
    name:'张三',
    age:22,
    arr:['1',2],
    arrObj:{
        name:'李四',
        sex:'女'
    }
}

let obj2 = {}; // 创建一个对象用于接收

function deepCopy(obj){
    let _obj = JSON.stringify(obj),
    objClone = JSON.parse(_obj);
    return objClone
}    
obj2 = deepCopy(obj1)
console.log(obj2)

需要注意的是:这种拷贝方法不可以拷贝一些特殊的属性(例如正则表达式,undefine,function)

工作中看自己实际需求,我这里写的也可能某些地方有缺陷,欢迎大佬指教

相关文章

  • iOS深拷贝(MutableCopy)与浅拷贝(Copy)的区别

    深拷贝和浅拷贝的概念 iOS中有深拷贝和浅拷贝的概念,那么何为深拷贝何为浅拷贝呢?浅拷贝:浅拷贝并不拷贝对象本身,...

  • iOS面试题-第二页

    11.深拷贝和浅拷贝的理解. 深拷贝;拷贝的内容. 浅拷贝:拷贝的指针. 深拷贝如: NSMutableDicti...

  • iOS - copy 与 mutableCopy

    一说到拷贝,就不得不提浅拷贝和深拷贝。 何谓浅拷贝?何谓深拷贝? 往简单的说: 浅拷贝:拷贝地址。 深拷贝:拷贝内...

  • JS中的深拷贝与浅拷贝

    知乎:js中的深拷贝和浅拷贝? 掘金: js 深拷贝 vs 浅拷贝 前言 首先深拷贝与浅拷贝只针对 Object,...

  • iOS--拷贝相关题

    1、什么是深拷贝什么是浅拷贝?浅拷贝和深拷贝的区别 * 浅拷贝(shallow copy):指针拷贝,对于被拷贝对...

  • copy和mutableCopy的区别

    copy和mutableCopy的区别 深拷贝和浅拷贝的区别 在OC中对象的拷贝方式有两种:深拷贝和浅拷贝.浅拷贝...

  • 2018-10-10函数基础

    深拷贝和浅拷贝 深拷贝 copy.deepcopy(对象)浅拷贝 copy.copy(对象)深拷贝: 将对象对应的...

  • Objective-C中的浅拷贝和深拷贝

    Objective-C中的浅拷贝和深拷贝 Objective-C中的浅拷贝和深拷贝

  • JavaScript的深拷贝和浅拷贝

    原文 博客原文 大纲 前言1、对深拷贝和浅拷贝的初步认识2、深拷贝和浅拷贝的区别3、浅拷贝存在的缺陷4、深拷贝的实...

  • java中的深拷贝和浅拷贝

    简单记录一下java中的深拷贝和浅拷贝,深拷贝和浅拷贝只是针对对象而言的. 1 深拷贝代码 2 浅拷贝代码 3 测...

网友评论

      本文标题:浅拷贝和深拷贝

      本文链接:https://www.haomeiwen.com/subject/ehaoshtx.html