原文来自FichC。
1)迭代是重复并反馈过程的动作,知道接近并达到所需的目标或结果;每一次对过程的重复被称之为一次‘迭代’,而每一次迭代得到的结果会被用作下一次迭代的初始值;
2)迭代并不是容器(列表,字典),迭代器就是实现了__next__()方法的对象(用于遍历容器中的数据);
3)迭代器没有办法回退的,只能前进;
4)判断一个容器是否具有迭代功能就是看该容器是否拥有魔法方法__iter__()和__next__();
5)迭代器通过__next__()方法每次返回一个值,并指向下一个元素,如果当前位置已无元素,则抛出异常,表明迭代器里边已经取空;
6)对于原生支持随机访问的数据结构(tuple,set),可以使用迭代器或者下标索引的方式访问,但对于无法随机访问的数据结构set而言,迭代器是唯一的访问元素的方式;
7)与以下for循环等同的while循环:
for each in range(5):
print(each)
while循环:需要先构建一个迭代器(构建迭代器需要使用一个列表作为参数),然后才能使用next方法;
alist=range(5)
it=iter(alist)
while True:
try:
print(next(it))
exception StopIteration:
break