迭代器

一、理解迭代器

迭代,重复产生结果的一个过程。上一次产生的结果为下一次产生结果的初始状态。

迭代器,用来迭代的工具。

可迭代对象:内置__iter__方法的对象。

1 'alex'.__iter__()
2 [2,4,6].__iter__()
3 (1,2,3).__iter__()
4 {'name':'alex','age':20}.__iter__()
5 {'alex','lvqj'}.__iter__()
6 open('a.txt','r','utf-8').__iter__()

迭代器对象:内置__iter__方法又内置__next__方法的对象。

#列表、字符串、元组可通过索引来获取元素,字典、集合则需要通过迭代器来迭代里面的元素。

#'alex'.__iter__()得到的迭代器对象仍然是一个迭代器对象。'alex'.__iter__().__iter__()。

#迭代器对象一定是可迭代对象,而可迭代对象不一定是迭代器对象。

二、迭代器的使用

1 l = [1,2,3,4,5]
2 iter_l = l.__iter__()
3 print(iter_l.__next__())   #等同于print(next(iter_l))

#当可迭代对象中无法被找到下一个结果时会抛出StopIteration异常,通常捕获该异常即可。

1 try:
2   print(iter_l.__next__())
3 except StopIteration:
4       break

三、for循环工作原理

for循环在工作的过程中,首先在内部对可迭代对象调用__iter__方法获取到迭代器对象,再一次一次的去通过迭代器对象调用__next__方法获取迭代的结果。

1 p = {'name':'alex','age':22}
2 for k in p:
3   print(k,'->',p[k])

四、迭代器优缺点

优点:可以不基于索引的方式获取可迭代对象中的元素。惰性计算,节省内存。

#获取文件中的内容,传统的方式是读取文件中的内容到内存空间中,极大占用内存空间。而使用迭代器可以一个迭代读取一段内容,充分节省内存空间。

缺点:不能知道可迭代对象的长度。只能往前走,不能往后走。

原文地址:https://www.cnblogs.com/lvqiuji/p/9535532.html