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

深拷贝与浅拷贝

作者: 南蓝NL | 来源:发表于2018-07-19 11:45 被阅读0次

浅拷贝就是复制某个对象的指针,新旧对象共享一个内存;深拷贝就是新旧对象各自占一块内存,不共享内存,新旧对象保持 不变

var a = 25;
var b = a;
b = 10;
console.log(a);//25
console.log(b);//10

//浅拷贝
var obj1 = { a: 10, b: 20, c: 30 };
var obj2 = obj1;
obj2.b = 40;
console.log(obj1);// { a: 10, b: 40, c: 30 } 
console.log(obj2);// { a: 10, b: 40, c: 30 }

//深拷贝
var obj1 = { a: 10, b: 20, c: 30 };
var obj2 = { a: obj1.a, b: obj1.b, c: obj1.c };
obj2.b = 40;
console.log(obj1);// { a: 10, b: 20, c: 30 }
console.log(obj2);// { a: 10, b: 40, c: 30 }

貌似我们在日常工作中常用的就是浅拷贝,怎么实现深拷贝呢.即新旧对象互不干扰.

浅拷贝的实现
var json1={"a":"name","arr1":[1,2,3,4]}
function copy(obj1){
var obj2 = {};
for(var i in obj1){
obj2[i] = obj[i];
}
return obj2;
}
var json2 = copy(json1);
json1.arr.push(4);
alert(json1.arr1); // 1234
alert(json2.arr2); // 1234
深拷贝的实现
//   方法1
  let foo = {   a:1,b:2,c:{ d:1 } }
  let bar = {};
  Object.assign(bar,foo); //这种深拷贝的方式针对于对象嵌套就木有用了
  foo.c.d++; // 浅拷贝 1,2,2  1,2,2
  foo.a++; // 深拷贝2,2,1  1,2,1
  console.log(foo,bar); 
// 方法2
  var obj1 = {body:{a:10}};
  var obj2 = JSON.parse(JSON.stringify(obj1));
  obj1.body.a = 20;
   console.log(obj1,obj2);//20,10

相关文章

  • JS中的深拷贝与浅拷贝

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

  • 认识js下的浅拷贝与深拷贝

    浅拷贝与深拷贝 首先深拷贝和浅拷贝只针对像 Object, Array 这样的复杂对象的。简单来说,浅拷贝只拷贝一...

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

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

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

    Objective-C中的浅拷贝和深拷贝IOS开发之深拷贝与浅拷贝(mutableCopy与Copy)详解iOS ...

  • 深拷贝和浅拷贝

    干货!深拷贝和浅拷贝的区别 深拷贝才是拷贝,浅拷贝就是Retain Copy与Retain的区别 Copy: 根据...

  • js浅拷贝、深拷贝

    前言 本文主要简单讲一下什么是浅拷贝、什么是深拷贝、深拷贝与浅拷贝的区别,以及怎么进行深拷贝和怎么进行浅拷贝。 一...

  • iOS 图文并茂的带你了解深拷贝与浅拷贝

    iOS 图文并茂的带你了解深拷贝与浅拷贝 iOS 图文并茂的带你了解深拷贝与浅拷贝

  • 深拷贝和浅拷贝

    1: iOS开发 深拷贝与浅拷贝 2: iOS 浅谈:深.浅拷贝与copy.strong 3: iOS开发——深...

  • [C++之旅] 15 深拷贝与浅拷贝

    [C++之旅] 15 深拷贝与浅拷贝 拷贝构造函数分为深拷贝和浅拷贝两种方式 浅拷贝只是将被拷贝的对象的成员直接赋...

  • 深拷贝VS浅拷贝

    深拷贝VS浅拷贝 本文主要对深拷贝&浅拷贝的解释及实现做一下简单记录。 之所以会有深拷贝与浅拷贝之分,是因为不同数...

网友评论

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

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