分别是等号,切片,copy和deepcopy
# *-*coding:UTF-8 *-*
import copy
# list赋值操作
a = [1, 2, 3, [4, 5]]
b = a
print(a is b) #True 即a, b公用内存
a[3] = 4
print('a : ', a) # [1, 2, 3, 4]
print('b : ', b) # [1, 2, 3, 4] 即:element也是共享
# 总结 赋值运算是一个浅拷贝,b指向a原来的内存
#list 切片
a = [1, 2, 3, [4, 5]]
b = a[:]
print(a is b) # a b 没有公用内存
a[0] = 2
print('a : ', a) # [2, 2, 3, [4, 5]]
print('b : ', b) # [1, 2, 3, [4, 5]] 即list最外侧的元素申请了一块新内存
a[3][0] = 100
print('a : ', a) # [2, 2, 3, [100, 5]]
print('b : ', b) # [2, 2, 3, [100, 5]]
# 即虽然最外侧元素申请了新的内存,但是a[3]本质是一个链表,赋值也就是在b[3]=a[3],这一部分仍然是浅拷贝
# 总结:切片是申请了新的内存地址,然后element之间一次用'='赋值,所以若list中包含list,那么element为list部分为浅拷贝
#copy 复制
a = [1, 2, 3, [4, 5]]
b = copy.copy(a)
print(a is b) # 不共用内存
a[0] = 2
print('a : ', a) # [2, 2, 3, [4, 5]]
print('b : ', b) # [1, 2, 3, [4, 5]] 即list最外侧的元素申请了一块新内存
a[3][0] = 100
print('a : ', a) # [2, 2, 3, [100, 5]]
print('b : ', b) # [2, 2, 3, [100, 5]]
# 和切片原理一样
#deepcopy 深拷贝
a = [1, 2, 3, [4, 5]]
b = copy.deepcopy(a)
a[3][0] = 0
print('a : ', a)
print('b : ', b)
# 顾名思义,不用细说