生成器

作者: NWKYEKJ | 来源:发表于2019-03-06 15:46 被阅读0次
概述

生成器是一种特殊的迭代器,它能够将保存某一计算结构,在每次迭代时再计算值,不像list直接保存了所有值,这样能够节省大量的内存空间。生成器的创建主要有两种方法,一是通过生成器生成式,二是通过yield语法。

  • 生成器生成式
    生成器生成式和列表生成式类似,只是将列表生成式的中括号改成了圆括号即可。
  • yield关键字
    yield语法和函数类似,将return改为yield即可,yield后跟随要生成的对象。

生成器也是一种迭代器,所以可以作为next函数的输入,或者用for循环迭代。当使用next函数时,生成器运行到yield关键字处时生成一个新的对象,然后在该处挂起。在下次使用时,生成器从该处开始执行,直到下一个yield生成新的对象时停止。若生成器函数执行完毕,抛出StopIteration错误。for循环能够捕捉到该错误以跳出循环。

send方法

在生成器中,yield关键字的左侧可以接返回值,这个对象用于接受一个值,通过生成器的send方法进行接收。如下面的例子,该例要计算任意长度数列的平均值,根据公式{\mu}_{k}={\mu}_{k-1}+\frac{1}{k}(x_{k}-{\mu}_{k-1})对平均值进行迭代。

def computeMean():
    num = yield 0
    mu = 0
    cnt = 0
    while True:
        if not num:
            break
        cnt += 1
        mu += (num - mu)/cnt
        num = yield mu
    return
g = computeMean()
next(g) # 预激生成器
for i in range(1, 6):
        print(g.send(i))

输出结果:

'''
1.0
1.5
2.0
2.5
3.0
'''

生成器需要先调用next函数产生第一个值后才能使用send方法,因为如果直接使用send方法,则没有对象接收这个参数。在调用next函数后,生成器在第一个yield关键字处挂起,这时候调用send方法后,生成器首先将值赋给num,然后再次执行到下一个yield关键词处,产生新值并挂起。可以看出yield关键字的返回值和要产生的新值之间没有关系。另外next方法没有传递新值,可看成send(None),使用send(None)也可对生成器进行预激励。

相关文章

  • 15.生成器generator

    目录:1.生成器介绍2.生成器举例3.生成器应用 1.生成器介绍 生成器指的是生成器对象,可以由生成器表达式得到,...

  • 2018-07-16

    ## 1\. 生成器和生成器函数 ``` 生成器的本质就是迭代器 生成器的三种创建办法: 1.通过生成器函数 ...

  • 第014篇:三大神器之生成器

    Python的三大神器:装饰器、迭代器、生成器 1、生成器 1.1、什么是生成器 生成器就是迭代器的一种;生成器作...

  • Python 生成器函数

    一、生成器 生成器指的是生成器对象,可由生成器表达式得到,也可使用 yield 关键字得到一个生成器函数,调用这个...

  • tornado协程的工作原理

    包含yield语句的函数是一个生成器。所有的生成器都是异步的。当我们调用生成器函数的时候,生成器函数返回一个生成器...

  • python 生成器小结

    作者:邵正将 来源:PytLab 在python中生成器可以很方便的实现迭代协议。生成器通过生成器函数产生,生成器...

  • ES6 Generators

    生成器函数 生成器函数以function*标注 yield关键字,会暂停生成器的执行,在之后可以继续执行 生成器的...

  • ES6 生成器Generator

    生成器 生成器(Generators): 一个更好的方法来构建遍历器。 --- 生成器和迭代器 生成器就是一类...

  • 生成器

    生成器指的是生成器对象,可以有生成器表达式获得,也可以由yield关键字得到一个生成器,调用这个函数得到一个生成器...

  • Python 入门之 Python三大器 之 生成器

    Python 入门之 Python三大器 之 生成器 1、生成器 (1)什么是生成器? 核心:生成器的本质就是一个...

网友评论

      本文标题:生成器

      本文链接:https://www.haomeiwen.com/subject/gyxtlqtx.html