在面试中我遇到这个问题,当时没想起来太多,一时之间讲的也不太好。我感觉应该将面试中遇到的问题记录下来,免得再次犯错。
迭代是访问集合元素的一种方式。迭代器是一个可以记住遍历位置的对象。迭代器对象从集合的第一个元素开始访问,直到所有元素被访问完结束。迭代器只能往前不能后退。
1、可迭代对象
以直接作用于for循环的数据类型有以下几种:
一类是集合数据类型,如list、tuple、dict、set、str等;
一类是generator,包括生成器和带yield的生成器函数。
这些可以直接作用于for循环的对象统称为可迭代对象:Iterable。
2、判断是否可以迭代
可以使用isinstance()判断一个对象是否是Iterable对象:
3、迭代器
可以被next()函数调用并不断返回下一个值的对象称为迭代器:Iterable。
可以使用isinstance()判断一个对象是否是Iterable对象:
4、iter()函数
生成器都是Iterator对象,但list、dict、str虽然是Iterable,却不是Iterator。把list、dict、atr等Iterable变成Iterator可以使用iter()函数
5、生成器
通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,而且当我们仅仅需要访问前面几个元素,那后面的大多数元素占用的空间都白白浪费了。所以我们使用生成器generator一边循环一边计算。
创建一个生成器有多种方法,最简单的一种就是将列表生成式的[]改为()
还可以使用生成器函数的方法
使用yield时,每调用一次函数的__next__()方法,就执行一次循环从而生成一个数据
总结:
1.迭代器都是可迭代对象,但是可迭代对象不一定是迭代器
2.生成器都是迭代器,但是迭代器不一定是生成器
3.可迭代数据类型list、str、dict等都是Iterable但不是迭代器Iterator,不过可以通过iter(list)函数获取一个迭代器对象