浅拷贝和深拷贝

Posted 万物有灵

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了浅拷贝和深拷贝相关的知识,希望对你有一定的参考价值。

作者:进击的袋鼠
链接:https://www.zhihu.com/question/23031215/answer/124017500
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

1,对于字符串类型,浅复制是对值的复制,对于对象来说,浅复制是对对象地址的复制,并没 有开辟新的栈,也就是复制的结果是两个对象指向同一个地址,修改其中一个对象的属性,则另一个对象的属性也会改变,而深复制则是开辟新的栈,两个对象对应两个不同的地址,修改一个对象的属性,不会改变另一个对象的属性。深复制实现代码如下:
可以从两个方法进行解决。
第一种方法、通过递归解析解决
 var china = {
	  	nation : ‘中国‘,
	  	birthplaces:[‘北京‘,‘上海‘,‘广州‘],
	  	skincolr :‘yellow‘,
	  	friends:[‘sk‘,‘ls‘]
	  }
	  //深复制,要想达到深复制就需要用递归
	  function deepCopy(o,c){
	    var c = c || {}
	    for(var i in o){
	    if(typeof o[i] === ‘object‘){
	  	   	   	  //要考虑深复制问题了
                      if(o[i].constructor === Array){
                    	//这是数组
                    	c[i] =[]
                    }else{
                    	//这是对象
                    	c[i] = {}
                    }
                    deepCopy(o[i],c[i])
	  	   	   }else{
	  	   	   	 c[i] = o[i]
	  	   	   }
	  	   }
	  	   return c
	  }
	  var result = {name:‘result‘}
	  result = deepCopy(china,result)
	  console.dir(result)
第二种方法:通过JSON解析解决
 var test ={
	  	name:{
	  	 xing:{ 
	  	     first:‘张‘,
	  	     second:‘李‘
	  	},
	  	ming:‘老头‘
	  },
	  age :40,
	  friend :[‘隔壁老王‘,‘宋经纪‘,‘同事‘]
	 }
	  var result = JSON.parse(JSON.stringify(test))
	  result.age = 30
	  result.name.xing.first = ‘往‘
	  result.friend.push(‘fdagldf;ghad‘)
	  console.dir(test)
	  console.dir(result)

以上是关于浅拷贝和深拷贝的主要内容,如果未能解决你的问题,请参考以下文章

NumPy之浅拷贝和深拷贝

C#的浅拷贝和深拷贝

js 对象的浅拷贝和深拷贝

python中的浅拷贝和深拷贝

JS-[浅拷贝和深拷贝]

js的浅拷贝和深拷贝