码迷,mamicode.com
首页 > 编程语言 > 详细

python基础 浅复制和深复制

时间:2017-10-30 19:40:12      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:数据   存储   做了   拷贝   app   深复制   一个   重复   就会   

一、变量赋值:
1、变量的初始化

变量的每一次初始化,都开辟了一个新的空间,将新内容的地址赋值给变量(即变量的内存地址改变)。对于下图来说,我们重复的给str1赋值,其实在内存中的变化如下右图:

  技术分享         技术分享

  从上图我们可以看出,str1在重复的初始化过程中,是因为str1中存储的元素地址由‘hello world‘的地址变成了‘new hello world‘的。

2、列表变量的增删改

  技术分享         技术分享

  当对列表中的元素进行一些增删改的操作的时候,是不会影响到lst1列表本身对于整个列表地址的,只会改变其内部元素的地址引用。可是当我们对于一个列表重新初始化(赋值)的时候,就给lst1这个变量重新赋予了一个地址,

覆盖了原本列表的地址,这个时候,lst1列表的内存id就发生了改变。上面这个道理用在所有复杂的数据类型中都是一样的。

3、变量赋值

(1)str的赋值

  技术分享           技术分享

  我们刚刚已经知道,str1的再次初始化(赋值)会导致内存地址的改变,从上图的结果我们可以看出修改了str1之后,被赋值的str2从内存地址到值都没有受到影响。

  看内存中的变化,起始的赋值操作让str1和str2变量都存储了‘hello world’所在的地址,重新对str1初始化,使str1中存储的地址发生了改变,指向了新建的值,此时str2变量存储的内存地址并未改变,所以不受影响。

(2)列表的赋值

  技术分享         技术分享

  上图对列表的增加修改操作,没有改变列表的内存地址,lst1和lst2都发生了变化。

  对照内存图我们不难看出,在列表中添加新值时,列表中又多存储了一个新元素的地址,而列表本身的地址没有变化,所以lst1和lst2的id均没有改变并且都被添加了一个新的元素。

  总结:无论对于列表的复杂结构、还是对于字符串的结构,只要对变量做了一次初始化,就会开辟一个新的存储空间(列表的增删改不会开辟新的内存空间)。这样赋值后的那个变量str2,还是指向第一次指向的内存空间str1(不会指向第二次初始化的变量值,即新的str1)

 

二、拷贝copy

浅拷贝:不管多么复杂的数据结构,浅拷贝都只会copy一层

>>> import copy
>>> list1=[1,2,3,[1,2,3]]
>>> list2=copy.copy(list1)
>>> print(list1)
[1, 2, 3, [1, 2, 3]]
>>> print(list2)
[1, 2, 3, [1, 2, 3]]
>>> list1.append(4)
>>> list1[3]=[1,2]
>>> print(list1)       
[1, 2, 3, [1, 2], 4]                    #  最外一层被复制了,开辟了新空间,原始数据的修改不会影响新数据
>>> print(list2)
[1, 2, 3, [1, 2, 3]]                   #  里层的不复制,并且list1[3]=[1,2]又开辟了新的空间,所以这里list2还是指向原空间[1, 2, 3]
>>> 

技术分享

 

 

深拷贝:

 

python基础 浅复制和深复制

标签:数据   存储   做了   拷贝   app   深复制   一个   重复   就会   

原文地址:http://www.cnblogs.com/nianyuxue/p/7755717.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!