python 生成器 & 迭代器

在聊生成器之前,我们先看看什么是生成式?

  a = [i*2 for i in range(10) ]    类似于这样的就是生成式

       python 生成器 & 迭代器_迭代器

 

  而把列表 “ [ ] ” 符号换成 " () " 则就称为 generator 类型

  python 生成器 & 迭代器_python_02

 

 

什么是生成器?

  在 Python 中,使用了 yield 的函数被称为生成器。

  跟普通函数不同的是,生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。

生成器的特点:

  1).只有在调用时才会生成相应的数据

  2).只记录当前位置

  3).只有一个__next__() 方法。在python2.7中是  next()

 

下面我们用斐波那契数列,写一个生成器:

python 生成器 & 迭代器_python_03

 

 

那么我们为什么要用生成器,它的优点是什么呢?

  由于生成器只有在调用时,才会生成数据,所以它可以节省内存占用。而且生成器可在单线程下实现并发运算处理效果,这点很牛逼。

以下是并行效果代码演示:

python 生成器 & 迭代器_迭代器_04

 

 

接下来我们来看看什么是迭代器?

  我们知道,可以直接作用于for 循环的数据类型有以下几种:

    一类是集合数据类型,如 list、tuple、dict、set、str 等;

    一类是generator,包括生成器和带yield的generator function。

    我们把这些可以直接作用于for循环的对象统称为可迭代对象:Iterable 。

  像生成器这样,不但可以作用于for循环,还可以被next() 函数不断调用并返回下一个值,

直到最后抛出StopIteration 错误表示无法继续返回下一个值了。我们把这种可以被next()函数

调用并不断返回下一个值的对象称为迭代器:Iterator。

  由此可见,我们可以知道,生成器肯定是一个迭代器,但迭代器不一定是生成器。

  当然我们也可以使用 iter() 函数,把可迭代对象(Iterable)变成迭代器(Iterator)

        python 生成器 & 迭代器_迭代器_05

 

        python 生成器 & 迭代器_生成器_06

 

 

小结:

  凡是可作用于for 循环的对象都是 Iterable 类型;

  凡是可作用于next() 函数的对象都是Iterator类型,它们表示一个惰性计算的序列;

  集合数据类型如list 、dict、str等是Iterable但不是Iterator,不过可以通过iter() 函数获得一个 Iterator 对象。