为什么会产生这个问题?
因为我写了一个有问题的代码,大概长下面这样
# 如下是一个简单的循环
l = ['abc' ,2 ,[1, 2, 3] ,4]
for i in l:
print(i)
l.remove(i)
print(l)
最后的输出是
abc
[1, 2, 3]
[2, 4]
踩坑的原因是,在遍历的时候,我根据一些条件去删除列表中的元素,然后偶然发现输出与我的预期并不符合。
原本的理解是next
会依次返回后面一个元素,因此现在这个元素我删了也没事。
但是事实显然不是这样,列表产生的迭代器返回值好像是根据索引返回的
大模型的回答不同模型直接存在差异,因此在翻了一些 blog ,有一篇里面有句话如下所示
==迭代器本身并不存储任何数据项,存储的只是一个指针,该指针指向可迭代对象中真正存储的数据项,它指向当前被遍历到的数据项索引位置,下一次遍历则向后推进这个位置==
所以再次来求助一下,迭代器的 next 是按照索引来获取数据的吗
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.