一、理解迭代器
迭代,重复产生结果的一个过程。上一次产生的结果为下一次产生结果的初始状态。
迭代器,用来迭代的工具。
可迭代对象:内置__iter__方法的对象。
'alex'.__iter__()
[2,4,6].__iter__()
(1,2,3).__iter__()
{'name':'alex','age':20}.__iter__()
{'alex','lvqj'}.__iter__()
open('a.txt','r','utf-8').__iter__()
迭代器对象:内置__iter__方法又内置__next__方法的对象。
#列表、字符串、元组可通过索引来获取元素,字典、集合则需要通过迭代器来迭代里面的元素。
#'alex'.__iter__()得到的迭代器对象仍然是一个可迭代对象。'alex'.__iter__().__iter__()。
#迭代器对象一定是可迭代对象,而可迭代对象不一定是迭代器对象。
二、迭代器的使用
l = [1,2,3,4,5]
iter_l = l.__iter__()
print(iter_l.__next__()) #等同于print(next(iter_l))
#当可迭代对象中无法被找到下一个结果时会抛出StopIteration异常,通常捕获该异常即可。
try:
print(iter_l.__next__())
except StopIteration:
break
三、for循环工作原理
for循环在工作的过程中,首先在内部对可迭代对象调用__iter__方法获取到迭代器对象,再一次一次的去通过迭代器对象调用__next__方法获取迭代的结果。
p = {'name':'alex','age':22}
for k in p:
print(k,'->',p[k])
四、迭代器优缺点
优点:可以不基于索引的方式获取可迭代对象中的元素。惰性计算,节省内存。
#获取文件中的内容,传统的方式是读取文件中的内容到内存空间中,极大占用内存空间。而使用迭代器可以一个迭代读取一段内容,充分节省内存空间。
缺点:不能知道可迭代对象的长度。只能往前走,不能往后走。