上周开发代码:遇见循环pop数据,导致后续的数据发生问题,没有达到预期值。
且以上pop数据不稳定,造成上述现象的原因是因为,Python中for i in list是用迭代器实现,内部隐藏了记录当前迭代器的状态,而remove、pop方法删除了当前元素后,迭代器自动指到下一个元素,原先的list在内存中的位置并未改变。用append方法可以避免。
同时, 提出把for i in x:改成for i in x[:]:也可以实现,这是因为x[:]与x不是同一个list,相当与把x的内存拷贝到一块新的内存,当对x做remove操作的时候,新的内存list并没有受影响。
x
=
[
'a'
,
'b'
,
'c'
,
'd'
]
y
=
[
'b'
,
'c'
]
for
i
in
x:
if
i
in
y:
x.remove(i)
print
x
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
result:
[
'a'
,
'c'
,
'd'
]
这之所以没有把C去掉 是因为你把B去掉以后,你还停留在B的位置。B删掉后,B的位置变成了C,下一个循环就变成了D的位置,所以跳过了C。