如何更好地理解python迭代器和生成器,主要区别是什么

兄弟姐妹们在线求帮请讲解下,如何更好地理解python迭代器和生成器,主要区别是什么
最新回答
安陵忻美

2024-11-30 18:09:11

打个比方,迭代就像爬楼梯,楼梯的台阶是数据序列中的元素,遍历迭代就像爬楼梯的双脚,一个接着一个地触及台阶,该过程就可以想象为遍历和迭代——脚在遍历,台阶在迭代。

而迭代器是什么,个人的理解是迭代器将迭代这种操作从for循环的“枷锁”中解脱出来,因为for循环遍历的时候一旦开启,就是从头到尾遍历一遍的,就像前面的爬楼梯,如果是使用for循环进行迭代,那么一般情况下都是要从第一级台阶一直爬到最后一级台阶,停不下来(除非设置条件,如break、continue之类的),而迭代器不用如此,可以更加灵活,通过next()函数,可以“随用随取”,第一级台阶爬完了,不想爬,就停在那里,等想爬了就继续用next()函数。

python的迭代器的这一特性可以很方便地用来开发可以通关的小 游戏 ,比起for循环来实在是方便许多,比如下面的 游戏 实例:

python迭代器,iter()函数,通关 游戏 实例 - 大器编程

python的生成器generator可以理解成为特殊的迭代器,具备迭代器的上述功能,与迭代器不同的是,生成器往往更多地运用于Python的函数,利用yield关键词将python的函数创建成生成器,如下面的代码:

代码解析

函数r()因为yield关键词变成了一个生成器,并且通过yiled关键词返回一个值,比如用next(ra)时,while第一次循环,函数返回0,并停止,当再次使用next(ra)时,函数从yield下面的i += 1处继续执行。

python生成器最大的作用之一就是节省程序执行过程中所占用的计算机内存,就像上面的实例代码。这个可能不明显,我们举个更明显的例子来说明一下,代码如下:

代码解析

我们将上面生成器推导式与列表推导式[ x for x in range(10) ]来进行一番比较,这个列表推导式为创建一个[0,1,2,...,9]的列表(如果元素个数多的话就占据很大的内存了),而上面的生成器推导式则不会那样的列表,而是通过next()函数逐一生成,比如第一次用next()时,“才”生成0,并作为返回值返回,第二次用next()函数,“才”生成1,并作为返回值返回,这样显然就不会占据太多的内存了,从而使python的程序变得高效一些。

更多关于生成器的介绍可以参考如下内容:

python的生成器的功能,yield关键词,实例解析 - 大器编程