[Python]append踩坑记录----深拷贝浅拷贝
问题
写一个range为(0,5)的顺序金字塔
[0]
[0],[0,1]
[0],[0,1],[0,1,2]
…
[0],[0,1],[0,1,2],[0,1,2,3],[0,1,2,3,4]
问题特别简单,简单的来写就是
tmp=[]
res=[]
for i in range(0,5):
tmp.append(i)
res.append(tmp)
print(res)
按理来说,按照此方法就可以得出想要的金字塔,可是输出却是:
不难发现,每一行都变成了一样的,并不是我们想要的金字塔。
原因
不难发现问题不是出在tmp.append(i)
而是出在 res.append(tmp)
这里。
res.append(tmp)
这一句只是简单的浅拷贝,也就是往res中添加的是tmp的地址,并不是真正复制了一份。当tmp改变时,随之在res中的值也会发生改变。所以res最后就保存了几个一模一样的值。
append() 函数
当 list 类型的对象进行 append 操作时,实际上追加的是该对象的引用。
解决
res.append(tmp)
换成 res.append(copy.deepcopy( num ))
或者改成切片的形式 res.append(tmp[:])