生成器

作者: IT孤独者 | 来源:发表于2018-01-10 11:02 被阅读0次

这个语法特性需要单独写一篇文章介绍。

在C/C++中是没有所谓的生成器的语法特性,简单的说就是没有 yield 关键字。那么就会有这个疑问,既然Python已经符合基本的语言完备性,为什么还要增加这个生成器的特性,究其原因就是因为生成器可以节省内存。

Python的内存管理是由解释器来完成的,对于列表这个及其特殊的内建数据结构,本身的特性是需要一片连续的地址空间(或者说逻辑上是连续的地址空间),导致如果需要循环一个大的列表,就必须先开辟这样的地址空间,这对于性能和空间来说都是挑战,有了生成器,我们只要能用表达式或者函数表示这个列表的生成规则,那么我们就可以一次只生成一个数据对象,供 for 语句消费,那么内存空间的需求就会减少很多。所以,生成器并不是书写Python 代码必要的工具,但是,这个工具有特殊的意义,就是对于列表空间的优化。我们知道不论是树形结构还是图形结构,我们都会涉及线性化的问题,简单说就是遍历的问题,而遍历的结果往往就是一个列表,所以,不用我说你也应该明白,生成器对于遍历某种数据结构的意义。

下面是一个合并两个有序序列,再对整个序列进行迭代的例子

def merge(a, b):
    i, j = 0, 0
    len_a, len_b = len(a), len(b)
    while True:
        if i >= len_a and j >= len_b:
            break
        if i >= len_a:
            yield b[j]
            j += 1
        elif j >= len_b:
            yield a[i]
            i += 1
        elif a[i] < b[j]:
            yield a[i]
            i += 1
        else:
            yield b[j]
            j += 1

if __name__ == '__main__':
    for item in merge([1, 4, 7, 10], [2, 5, 6, 11]):
        print(item, end=',')

相关文章

  • 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/zlannxtx.html