一直以来迭代器和生成器都是很神秘的,听起来就感觉很难,今天正好看到,打算写一下,记录一下。
1.迭代器
迭代器是访问集合元素的一种方式,迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问结束,但是整个过程只能前进不能后退,一直到全部的元素被访问结束。另外,迭代器的特点是不需要所有的元素全部准备好才开始,只要到这个元素之前获取这个元素就可以,这样可以遍历一些大的数据和集合。
特点:(借鉴了其他人的内容):
1.访问者不需要关心迭代器内部的结构,仅需要通过next() 方法不断去取下一个内容
2.不能随机访问集合中的某个值,只能从头到尾依次访问
3.访问到一半的时候不能往回退
4.便于循环比较大的数据集合,节省内存
贴上我的代码段:
2.生成器
一个函数调用时返回一个迭代器,那么这个函数就叫做生成器(generator),如果函数中包含yield语法,那这个函数就会变成生成器。
func() 称之为生成器,执行这个函数的时候会生成迭代器。
实例: