列表的copy方法:
s = [1,'yuyang','DBA']
s1 = s.copy()
print(s1)
s1[0] = 2
print(s)
print(s1)
结果:
[1, 'yuyang', 'DBA']
[1, 'yuyang', 'DBA']
[2, 'yuyang', 'DBA']
Process finished with exit code 0
浅拷贝:
浅拷贝就是指拷贝第一层
浅拷贝的两种方式:
s = [[1,2],'yuyang','DBA']
s1 = s.copy()
或者
s1 = s[:]
示例:
s = [[1,2],'yuyang','DBA']
s1 = s.copy()
print(s)
print(s1)
s1[0][1] = 3
print(s1)
print(s)
执行结果:
[[1, 2], 'yuyang', 'DBA']
[[1, 2], 'yuyang', 'DBA']
[[1, 3], 'yuyang', 'DBA']
[[1, 3], 'yuyang', 'DBA']
Process finished with exit code 0
从上面的程序执行结果中,可以看到,在修改s1(拷贝)列表中的列表的某一个元素的时候,修改后,s和s1都被修改了。这种情况就说明,s和s1是有关联的。
浅拷贝两个列表之间的关系示意图:
-
所以从上面可以看出,我们在修改字符数字的等数据类型的时候,不会出现浅拷贝的现象,但是在修改列表的时候由于父列表指向子列表的内存地址不变,但是子列表指向的内存地址发生变化,所以出现浅拷贝的现象。
-
如果我们是修改列表中的字典的话,出现的情况都是一样的,因为列表和字典都是可变的对象。
-
也就是说浅拷贝只会拷贝第一层
copy()和=的区别理解:
s = [[1,2],'yuyang','DBA']
s1 = s #两个变量完全相等
s1[1] = 'zhangsan' #修改s1的一个元素
print(s)
print(s1) #从打印结果中来看,是两个都被修改了的
s2 = s[:] #s2浅拷贝s
s2[2] = 'PM' #修改s2中一个元素
print(s)
print(s1)
print(s2) #从打印结果中看,原来两个变量(列表没有被修改,只有浅拷贝的s2自己修改了,这里就体现出做浅拷贝和=的区分)
执行结果:
[[1, 2], 'zhangsan', 'DBA']
[[1, 2], 'zhangsan', 'DBA']
[[1, 2], 'zhangsan', 'DBA']
[[1, 2], 'zhangsan', 'DBA']
[[1, 2], 'zhangsan', 'PM']
Process finished with exit code 0
pycharm中多行注释的快捷键是:
Ctrl + /
示例:
print('STEP1'.center(30,'-'))
a = 1
b = a
print(a)
print(b)
print('---')
print(id(a))
print(id(b))
print('STEP2'.center(30,'-'))
b = 2
print(a)
print(b)
print('---')
print(id(a))
print(id(b))
print('STEP3'.center(30,'-'))
a = [1,2]
b = a
print(a)
print(b)
print('---')
print(id(a))
print(id(b))
print('STEP4'.center(30,'-'))
b[1] = 3
print(a)
print(b)
print('---')
print(id(a))
print(id(b))
执行结果:
------------STEP1-------------
1
1
---
1767416928
1767416928
------------STEP2-------------
1
2
---
1767416928
1767416960
------------STEP3-------------
[1, 2]
[1, 2]
---
1365916817416
1365916817416
------------STEP4-------------
[1, 3]
[1, 3]
---
1365916817416
1365916817416
Process finished with exit code 0
-
从上面的代码中,可以看出,对于STEP2和STEP4,同样是修改b变量,但是STEP4中的a也跟着变了。
-
原因是:变量指向的是内存地址,对于不可变的对象,修改对象,则会开辟一个新的内存地址,存储新的内容,下次读取变量的时候,根据内存地址找到这个内容。但是对于可变对象,变量指向的是可变对象这个整体,比如说是列表这个整体,那么修改列表中的某一个元素的时候,只是列表再指向元素的内存地址变化了,但是变量指向列表的内存地址没有变,所以这里在修改b中的某一个元素的时候,发现修改后,a也变化了。
-
利用id方法打印出来变量的内存地址,可以发现对可变对象和不可变对象修改后,对ab两者的影响。
深拷贝
深拷贝就是克隆一份,就是完全复制
import copy
s = [[1,2],'yuyang','DBA']
s1 = copy.deepcopy(s)
print(s1)
结果:
[[1, 2], 'yuyang', 'DBA']
Process finished with exit code 0
示例:
import copy
s = [[1,2],'yuyang','DBA']
print(s)
s1 = copy.deepcopy(s) #深拷贝
s2 = s.copy() #浅拷贝
#s2 = copy.copy(s) #也是浅拷贝和上一行的执行结果一致
s1[0][1] = 3
s2[0][1] = 4
print(s)
print(s1)
print(s2)
执行结果:
[[1, 2], 'yuyang', 'DBA']
[[1, 4], 'yuyang', 'DBA']
[[1, 3], 'yuyang', 'DBA']
[[1, 4], 'yuyang', 'DBA']
Process finished with exit code 0