首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

搞定 JS 深浅拷贝

拷贝与深拷贝的区别 浅拷贝是创建一个新的对象,如果属性是基本类型,拷贝的就是基本类型的值,如果属性是引用类型,拷贝的就是内存地址。如果这个内存地址的值发生了变化,就会影响到其他的对象。...深拷贝是将一个对象从内存中完整拷贝一份出来,从内存中开辟一个新的区域放新对象,并且修改新对象不会影响原对象。 总而言之,浅拷贝只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存。...但深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。 ? ?...2 ] } console.log('obj2', obj2) // obj2 { name: '小小鑫', arr: [ 1, [ 1, 2 ] ] } niceeeeeeeeee~ 首发自:搞定 JS...深浅拷贝 - 小鑫の随笔

75430
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS复习之深浅拷贝

    一、复习导论(数据类型相关)   想掌握JS深浅拷贝,首先来回顾一下JS的数据类型,JS中数据类型分为基本数据类型和引用数据类型。   ...因此当操作结束后,这两个变量实际上指向的是同一个在堆内存中的对象,改变其中任意一个对象,另一个对象也会跟着改变。于是在引用数据类型的复制过程中便出现了深浅拷贝的概念。...二、深浅拷贝的区别   浅拷贝,对于目标对象第一层为基本数据类型的数据,就是直接赋值,即传值;而对于目标对象第一层为引用数据类型的数据,就是直接赋存于栈内存中的堆内存地址,即传地址,并没有开辟新的栈,也就是复制的结果是两个对象指向同一个地址...深拷贝,则是开辟新的栈,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性。...三、浅拷贝的实现方式   1.对象的浅拷贝     (1)Object.assign()       ES6中新增的方法,用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target

    37630

    深浅拷贝

    最常用的深拷贝方法 1.Object.assign 此方法是es6新推出来的方法,目的是将所有可枚举属性的值从一个或多个源对象分配到目标对象 Object.assign(目标对象, 源对象)该方法参数可以有一个...,将下标转换为键,然后进行对象合并 Object.assign([2,3], [5]); // [5,3] 注意:assign 的属性拷贝是浅拷贝(踩过的深坑) 2.无意中看到一种方法,效果与assign...虽然这种方法可以成功实现嵌套属性的深拷贝,但是也有许多弊端。...如果对象中存在循环引用的情况也无法正确实现深拷贝; 4.自定义对象数组深拷贝 function deepClone(obj) { if (typeof obj !...== "object") { return "克隆的值不是对象哦"; } //判断拷贝的要进行深拷贝的是数组还是对象,是数组的话进行数组拷贝对象的话进行对象拷贝 var objClone

    43341

    深浅拷贝

    是因为Java给我们做了一个偷懒性的拷贝动作,Object类原本就提供一个方法clone用来拷贝对象,因为其对象内部的数组、引用对象等都不拷贝,还是指向了原生对象的内部元素地址,这种拷贝就叫做浅拷贝。...浅拷贝 上面这个拷贝也太浅了吧,两个对象引用都boby、myBaby共享一个私有变量list,都可以对list进行改变,是一种非常不安全的方式。 ?...,两个对象引用指向的就不再是同一个地址了。...这就是深拷贝。 深拷贝还有一种实现方式:通过写自己的二进制流来操作对象,然后实现对象的深拷贝。...clone与final两个冤家 对象的clone与对象内的final关键字是有冲突,前者是要重新赋值,后者是赋值了就不能变了。

    48730

    拷贝构造与深浅拷贝

    如果没有定义一个拷贝构造函数,编译器会自动为我们定义一个,与合成拷贝构造函数。 合成拷贝构造函数用来阻止我们拷贝该类类型的对象。合成的拷贝构造函数会将其参数的成员逐个拷贝到正在创建的对象中。...每个成员的类型决定了它如何拷贝,对于类类型的成员,会使用其拷贝构造函数来拷贝,内置类型的成员则直接拷贝。...拷贝初始化,要求编译器将右侧运算对象拷贝到正在创建的对象中,如果有需要还要进行类型转换。...三、深浅拷贝 先来看代码 #include using namespace std; class person { public: person() { cout << "person...:myage = p.myage; 深拷贝:myheight = new int(*p.myheight); 拷贝函数:person p2(p1);、 进行析构时,由于创建了两个对象

    16520

    Python对象深浅拷贝,你到底变不变

    在Python有个重要的东西,就是对象深浅拷贝。...我们就称为:'==' vs 'is' == 比较对象之间的值是否相等 is 比较的是对象身份是否相等,它们是否同一个对象 我们一般通过id来是否相等来判断是否同一个对象 a = 10 b = 10 a...首先初始化一个列表l1,里面的元素是一个列表和元组,然后对l1执行浅拷贝,赋予了l2 ,但是l2中的元素和l1指向同一个列表和元组对象,只有列表对象变,你浅拷贝就要跟着我变。...如果你添加一个序列来,我浅拷贝没有指向你新来的对象。我干嘛跟着你变。 l1.append(100)l1的列表新增元素100,不会对l2产生影响,l1和l2是两个不同的对象 如果我在元组加呢???...深度拷贝 深度拷贝,就是你爱怎么变,就去哪里变,我就不变了。

    38130

    Python深浅拷贝

    深浅拷贝 深浅拷贝分为两部分,一部分是数字和字符串另一部分是列表、元组、字典等其他数据类型。 数字和字符串 对于数字和字符串而言,赋值、浅拷贝和深拷贝无意义,因为他们的值永远都会指向同一个内存地址。...)# var4的内存地址和var1相同>>> id(var4)1347747440 其他数据类型 对于字典、元祖、列表 而言,进行赋值、浅拷贝和深拷贝时,其内存地址的变化是不同的。...浅拷贝,在内存中只额外创建第一层数据 # 导入拷贝模块>>> import copy>>> var1 = {"k1": "1", "k2": 2, "k3": ["abc", 456]} # 使用浅拷贝的方式...深拷贝,在内存中将所有的数据重新创建一份(排除最后一层,即:python内部对字符串和数字的优化) # 导入拷贝模块>>> import copy>>> var1 = {"k1": "1", "k2"...: 2, "k3": ["abc", 456]} # 使用深拷贝的方式把var1的内容拷贝给var2>>> var2 = copy.deepcopy(var1) # var1和var2的内存地址是不相同的

    38910

    JavaScript的深浅拷贝

    在JavaScript中,拷贝一个对象是一项非常常见的操作,常用的方法包括深拷贝和浅拷贝。但是,不同的拷贝方法会产生不同的效果和影响,因此深入了解和掌握深浅拷贝的概念和实现方法是非常重要的。...浅拷贝首先我们来了解一下浅拷贝的概念。简单地说,浅拷贝就是只复制了对象的引用,而没有复制对象本身。也就是说,如果我们修改了浅拷贝后的对象,原对象也会跟着被修改。那么如何实现浅拷贝呢?...深拷贝相对于浅拷贝,深拷贝会复制整个对象,包括它的所有属性和嵌套对象。这种拷贝方式可以独立地修改新对象,不会对原对象产生任何影响。...选择浅拷贝还是深拷贝?选择浅拷贝还是深拷贝,取决于我们的实际需求和对对象引用关系的理解。...深拷贝适用于对象结构较复杂、包含嵌套对象或需要独立修改新对象的情况,例如在实现撤销重做功能时需要保存历史状态,此时使用深拷贝可以保证历史状态的独立性。

    14700

    js对象拷贝方法

    (obj) ); Object.assign(targetObj,sourceObj),浅拷贝 不是深拷贝,循环引用、各种数据类型都可以拷贝,引用类型不是深拷贝 它不会拷贝对象的继承属性; 它不会拷贝对象的不可枚举的属性...; 不可以拷贝对象中的对象; 可以拷贝 Symbol 类型的属性; 无法正确拷贝属性和属性 可以拷贝undefined/boolean/null/function/Date/RegExp/array/array...中的对象; 参考阮一峰文档: https://es6.ruanyifeng.com/#docs/object-methods#Object-assign 扩展运算符,浅拷贝 不是深拷贝,循环引用、各种数据类型都可以拷贝...,引用类型不是深拷贝 JSON.parse(JSON.stringfiy()),不完全深拷贝 拷贝对象的值中如果有函数、undefined、symbol 这几种类型,经过 JSON.stringify...序列化之后的字符串中这个键值对会消失; 拷贝 Date 引用类型会变成字符串; 无法拷贝不可枚举的属性; 无法拷贝对象的原型链; 拷贝 RegExp 引用类型会变成空对象对象中含有 NaN、Infinity

    2.4K20

    深浅拷贝知多少?

    下面就 针对在什么情况下赋值会改变原有对象的值进行进一步说明。首先带你了解下数据类型和基础概念。  JS数据类型 JS数据类型分为:基本数据类型和对象数据类型。...基础概念 浅拷贝 概念:只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存 深拷贝 概念:会另外创造一个一模一样的对象,新对象跟原对象不共享内存 ?...总结:name是基础数据类型,自然不用说,status是对象数据类型,由于深拷贝是层层递进拷贝,并不只是一层,所以拷贝后的新对象和原对象是完全独立的,无论哪个改变,也不会改变另外一个对象的内容。...特殊情况 js总是会有一些特殊情况,所以开发时要更加谨慎,深拷贝也并不是能拷贝所有的类型,例如下面的symbol,因为它是特殊的! ? ?...浅拷贝:虽然不是同一对象,但是如果原数据都是基础数据类型,浅拷贝就是深拷贝,各自独立,否则如果有对象数据类型,就会出现联动现象。

    35510

    Python深浅拷贝图解

    Python中,对象的赋值,拷贝(深/浅拷贝)之间是有差异的,如果使用的时候不注意,就可能产生意外的结果。 下面本文就通过简单的例子介绍一下这些概念之间的差别。 1.对象赋值 直接看一段代码: ?...分析一下这段代码: 首先,依然使用一个will变量,指向一个list类型的对象; 然后,通过copy模块里面的浅拷贝函数copy(),对will指向的对象进行浅拷贝; 然后浅拷贝生成的新对象赋值给wilber...分析一下这段代码: 首先,同样使用一个will变量,指向一个list类型的对象; 然后,通过copy模块里面的深拷贝函数deepcopy(),对will指向的对象进行深拷贝,然后深拷贝生成的新对象赋值给...跟浅拷贝类似,深拷贝也会创建一个新的对象,这个例子中"wilber is not will"。...5.总结 本文介绍了对象的赋值和拷贝,以及它们之间的差异: Python中对象的赋值都是进行对象引用(内存地址)传递 使用copy.copy(),可以进行对象的浅拷贝,它复制了对象,但对于对象中的元素

    72560

    string管理:深浅拷贝&写时拷贝

    由此 -> 引出深浅拷贝的概念 浅拷贝拷贝也称为位拷贝,当不存在拷贝构造函数或者重载的赋值运算符时,编译器会将对象中的值拷贝过来。...深拷贝拷贝是为了解决浅拷贝的问题,每个对象都有一份独立的资源,不与其他对象共享。这样,当一个对象销毁时,其他对象的资源不会受到影响。...深拷贝触发:当一个对象试图修改共享资源时,如果引用计数大于1,则执行深拷贝,这样修改不会影响其他共享该资源的对象。 析构函数:当对象销毁时,如果引用计数减为0,则释放资源。...先构造的对象后析构的影响 考虑如下情景: 对象A的构造:对象A创建时分配资源,引用计数为1。 对象B的构造(通过拷贝构造):对象B通过拷贝构造从对象A创建,引用计数增加到2。...由于对象B是从对象A拷贝构造而来的,在对象B修改资源前引用计数已经增加,因此写时拷贝能够正常工作。因为对象的生命周期顺序(先构造的对象后析构),确保了引用计数正确管理资源的分配和释放。

    12710
    领券