• 列表生成器


    第一种:
    a(i  for i in range(5))
    next(a)
    # 到最后一个会报错

    for i in a:
        print(a)  # 不会报错

    第二种:
    def fib(max):
        n, a, b = 0, 0, 1
        while n < max:
            yield b  # 把函数的执行过程冻结在这一步,并且把b的值返回给外面的next,把函数生成一个生成器
            a, b = b, a + b
            n = n + 1
        return 'done'

    f = fib(15)
    for i in f:
        print(i)


    python2
        range  = list
        xrange = 生成器
        
    python3
        range = 生成器
        xrange  没有
        
    生成器的创建方式
        1、列表 生成 式()
        2、函数
        
        yield vs return
        
        return 返回 并中止function
        yield  返回 数据,并冻结当前的执行过程
        
        next 唤醒冻结的函数执行过程,继续执行,知道遇到下一个yield
        
        生成器中有return 报错,相当于生成器中止了
        
    函数有了yield 之后
        1、函数名加() 就得    到了一个生成器
        2、return 在生成器里, 代表 生成器的中止,直接 报错
    next
        唤醒 生成器并继续 执行

    示例:
    def range2(n):
        count = 0
        while count < n:
            print('count', count)
            count += 1
            sign = yield count
            if sign == 'stop':
                print('-------sign', sign)
                break
        return 3333
        

    new_range = range2(3)

    n1 = next(new_range)

    new_range.send('stop')
    #1、唤醒并继续执行
    #2、发送一个信息到生成 器内部

    new_range.send(None)  # 第一次是发送一个None,next()相当于发送了一个None,send() 可以发送别的

  • 相关阅读:
    Markdown的简介(转)
    写在二月的尾巴上
    The Pragmatic Programmer 读书笔记
    C/C++语言的一些精简归纳
    一般常用设计模式及原则的思想小结
    常用UML模型简要小结
    LeetCode 101. Symmetric Tree
    LeetCode 100. Same Tree
    LeetCode 99. Recover Binary Search Tree
    线索二叉树的建立与遍历
  • 原文地址:https://www.cnblogs.com/fmgao-technology/p/9063204.html
Copyright © 2020-2023  润新知