迭代器定义:
可迭代协议:含有iter方法的都是可以迭代的
迭代器协议: 有.next 方法,和iter的都是迭代器
必须存在终结
特点:
节省空间
方便逐个取值,一个迭代器只能取一次
简单来说:满足可迭代协议以及迭代器协议的就可以被定义为迭代器
iter()-----等同于-------->.__iter__() 作用相等
next()-----等同于-------->.__next__() 作用相等
字符串,列表,元祖,字典,集合,文件对象 都不是可迭代对象
除非加上__iter__()方法才可以迭代
可迭代对象才可以调用__next__()方法
for循环机制内部原理
1. 调用了_iter_()方法,把列表变成可迭代对象
2. 调用_next_()方法迭代读取,直到捕捉到异常然后结束
3. 捕捉到异常,处理异常状态然后正常结束for循环
1 l = [1,2,3]
2 for i in l:
3 print(i)
1 l = [1,2,3]
2 iter_test = l.__iter__()
3 print(iter_test.__next__())
4 print(iter_test.__next__())
5 print(iter_test.__next__())
6 print(iter_test.__next__())
如果不要for 循环我们可以用while来循环达到相同的效果
1 l = [1,2,3,4,5]
2 index = 0
3 while index<len(l):
4 print(l[index])
5 index += 1
既然while可以完成工作,为毛还需要for呢?
while你很能啊,字典集合哪来的下标,你再试试看啊?
而for是可以的。for可以遍历非序列类型,文件,字典,集合,在这一点上for循环就甩开了while十条街。
集合的for循环机制
1 dis = {1,2,3}
2 # for i in dis:
3 # print(i)
4
5 iter_dis = dis.__iter__()
6 print(iter_dis.__next__())
7 print(iter_dis.__next__())
8 print(iter_dis.__next__())
字典的for循环机制
字典的for循环默认的执行得出的结果就是key的循环
1 dic = {"a":1,"b":2}
2 # for i in dic:
3 # print(i)
4 # print(dic[i])
5
6 iter_dic = dic.__iter__()
7 print(iter_dic.__next__())
8 print(iter_dic.__next__())
文件的for循环机制
1 f = open("test.txt","r+")
2 # for i in f:
3 iter_f = f.__iter__()
4 print(iter_f.__next__())
5 print(iter_f.__next__())
6 print(iter_f.__next__())
next()-----等同于--------> .__next__()
1 l = ["die","erzi","sunzi","chongsunzi"]
2 iter_l = l.__iter__()
3 # print(iter_l.__next__())
4 # print(iter_l.__next__())
5 # print(iter_l.__next__())
6 # print(iter_l.__next__())
7
8 print(next(iter_l))
9 print(next(iter_l))
10 print(next(iter_l))
11 print(next(iter_l))