面试篇---1 如何区分深拷贝与浅拷贝

栏目: JavaScript · 发布时间: 5年前

内容简介:简单来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝,拿人手短,如果B没变,那就是深拷贝,自食其力。浅拷贝例子:

如何区分深拷贝与浅拷贝?

简单来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝,拿人手短,如果B没变,那就是深拷贝,自食其力。

浅拷贝例子:

var a=[0,1,2,3,4],
       b=a;
    console.log(a===b);
    a[0]=1;
    console.log(a,b);

面试篇---1 如何区分深拷贝与浅拷贝

嗯?明明b复制了a,为啥修改数组a,数组b也跟着变了,这里我不禁陷入了沉思。

那么这里,就得引入基本数据类型与引用数据类型的概念了。

面试常问,基本数据类型有哪些,number,string,boolean,null,undefined五类。

引用数据类型(Object类)有常规名值对的无序对象{a:1},数组[1,2,3],以及函数等。

而这两类数据存储分别是这样的:

a.基本类型--名和值存储在栈内存中,例如let a=1;

面试篇---1 如何区分深拷贝与浅拷贝

当你b=a复制时,栈内存会新开辟一个内存,例如这样:

面试篇---1 如何区分深拷贝与浅拷贝

所以当你此时修改a=2,对b并不会造成影响,因为此时的b已自食其力,翅膀硬了,不受a的影响了。虽然b不受a影响, 但这也算不上深拷贝,因为深拷贝本身只针对较为复杂的object类型数据。

b.引用数据类型--名存在栈内存中,值存在于堆内存中,但是栈内存会提供一个引用的地址指向堆内存中的值,我们以上面浅拷贝的例子画个图:

面试篇---1 如何区分深拷贝与浅拷贝

当b=a进行拷贝时,其实复制的是a的引用地址,而并非堆里面的值。

面试篇---1 如何区分深拷贝与浅拷贝

而当我们a[0]=1时进行数组修改时,由于a与b指向的是同一个地址,所以自然b也受了影响,这就是所谓的浅拷贝了。

面试篇---1 如何区分深拷贝与浅拷贝

那,要是在堆内存中也开辟一个新的内存专门为b存放值,就像基本类型那样,岂不就达到深拷贝的效果了.

面试篇---1 如何区分深拷贝与浅拷贝

那么如何实现深拷贝呢?

1、我们可以借用JSON对象的parse和stringify

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

面试篇---1 如何区分深拷贝与浅拷贝

现在b完全不受a的影响了。

2、借用JQ的extend方法。

$.extend( [deep ], target, object1 [, objectN ] )

deep表示是否深拷贝,为true为深拷贝,为false,则为浅拷贝

target Object类型 目标对象,其他对象的成员属性将被附加到该对象上。

object1 objectN可选。 Object类型 第一个以及第N个被合并的对象。

let a=[0,1,[2,3],4],
    b=$.extend(true,[],a);
a[0]=1;
a[2][0]=1;
console.log(a,b);

面试篇---1 如何区分深拷贝与浅拷贝

其实深拷贝也不仅仅是为了应付面试题, 在实际开发中也是非常有用的。 例如后台返回了一堆数据,你需要对这堆数据做操作,

但多人开发情况下,你是没办法明确这堆数据是否有其它功能也需要使用, 直接修改可能会造成隐性问题,深拷贝能帮你更安全安心的去操作数据,

根据实际情况来使用深拷贝,大概就是这个意思。

原文链接 https://www.cnblogs.com/echol...


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Java Servlet & JSP Cookbook

Java Servlet & JSP Cookbook

Bruce W. Perry / O'Reilly Media / 2003-12-1 / USD 49.99

With literally hundreds of examples and thousands of lines of code, the Java Servlet and JSP Cookbook yields tips and techniques that any Java web developer who uses JavaServer Pages or servlets will ......一起来看看 《Java Servlet & JSP Cookbook》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具