for in 语句是对列表的索引操作,也就是基于索引进行遍历,虽然你代码里的i代表是元素,但执行remove(i)时,会把i元素所占用的内存空间释放,然后后面的元素填充进来。
详细说明如下,为了方便解释,把你列表里面的三个D,编下号分别为D1、D2、D3。
当你执行第三次循环时,index=2,对应的i=C,不满足条件,此次循环后,列表内容如下index: 0---1---2---3-----4----5
elemt: A--B---C---D1---D2---D3
当你执行第四次循环时,index=3,对应id=D1,满足条件,执行以下操作index: 0---1---2---3--------4----5
elemt: A--B---C---None---D2---D3
index: 0---1---2---3-----4
elemt: A--B---C---D2---D3
当你你删掉了一个元素D(即D1),后面的D会补进来,这样子D2占据了D1的位置,D3占据了D2的位置,而D3的位置会被释放,这样子列表长度就少1。
不过要注意的是,此时index=3,对应的id=D2
当你执行第五次循环时,index=4,对应的id=D3,满足条件,执行以下操作index: 0---1---2---3-----4
elemt: A--B---C---D2---None
index: 0---1---2---3
elemt: A--B---C---D2
同样的道理,D3被删,(不是D2啊,因为索引index=4,对应的是D3,而不是D2),后面没有元素补进来,直接释放D3的位置即可。
由于此时列表长度已经变成了4,index=5已经不满足循环条件了,直接退出。此时列表的内容,如上,D2直接换成D即可。
如果你理解了,可以思考下把列表改成['A', 'B', 'C', 'D', 'D', 'D', 'D']后,结果会是怎样。