迭代器概述
迭代器是访问集合内元素的一种方式。迭代器对象从集合的第一个元素开始访问,直到所有的元素都被访问一遍后结束。
迭代器的缺点:
(1)迭代器不能回退去取原来的元素,只能往前进行迭代。(当然这个缺点也不算是什么缺点因为我们基本上不会这么做)
(2)迭代器也不是线程安全的,在多线程环境中对可变集合使用迭代器是一个危险的操作。
迭代器的优点:
(1)对于原生支持随机访问的数据结构(如tuple、list),迭代器和经典for循环的索引访问相比并无优势,反而丢失了索引值,但对于无法随机访问的数据结构(比如set)而言,迭代器是唯一的访问元素的方式。
(2)迭代器的另一个优点就是它不要求你事先准备好整个迭代过程中所有的元素。这样在遍历一个庞大的集合时比如几个G的那么可以大大节省空间,这种特点被称为延迟计算或惰性求值(Lazy evaluation)。
使用迭代器:
(1)iter(iterable)使用内建的函数iter(iterable)可以获取迭代器对象:
lis = range(3)
it = iter(lis)
print (it)
(2)使用next()方法可以访问下一个元素:
1 lis = range(3)2 it =iter(lis)3 print(it)4 print(it.next(),next(it))5 #第一个方法是调用迭代器内置方法,第二种方法是使用内置函数在python 2.6以上版本
访问元素
当我们取完值后想要继续取值就会抛出StopIteration异常,这正是python根据是否检测到这个异常来决定是否停止迭代的
Traceback (most recent call last):
File "E:/pycharm/exercise/����/labda.py", line 17, in
print (it.next(),next(it),it.next(),it.next())
StopIteration