这里面说生成器最大的好处是可以省内存空间。

因为生成器generator,是一个一个生成数据的。在生成的过程中,你可以进可以出,可以做点别的事情。哈哈~~~

上代码:这里要插一个叫做列表生成式的东西,就是一句话写出一个列表。

这个就是最简单的列表生成式,稍微改动一下,它就变成了生成器。

看到吗,唯一的区别就是列表生成式是中括号,生成器是圆括号。

稍微复杂一点的生成器可以用函数来表示,例如斐波那契数列。

# __*__ coding: utf-8 __*____author__ = "David.z"def fib(max):    n,a,b=0,0,1while n < max:yield b        a,b = b, a+b        n = n+1return 'done'print(type(fib(10)))print(fib(10))f = fib(10)print(f.__next__())print(f.__next__())print("==========")print(f.__next__())print(f.__next__())print(f.__next__())print("Start Top".center(20,"*"))for i in f:print(i)

这样就实现了可进可出,还有更牛逼的。

例如吃包子。

def consumer(name):print("%s 准备吃包子了!"%name)while True:        baozi = yieldprint("包子[%s]来了,被[%s]吃了!"%(baozi,name))c = consumer("david.z")c.__next__()b1="红豆馅"c.send(b1)c.__next__()

这里引用了一个send命令,可以把做好的包子馅放入到生成器里面。

最后,实现一个单线程实现多并发的效果。也使用生成器,实际上就是生成器一步一步的出来。

import timedef consumer(name):print("%s 准备吃包子了!"%name)while True:        baozi = yieldprint("包子[%s]来了,被[%s]吃了!"%(baozi,name))c = consumer("david.z")c.__next__()b1="红豆馅"c.send(b1)c.__next__()def producer(name):    c = consumer("A")    c2 = consumer("B")    c.__next__()    c2.__next__()print("老子开始准备做包子了!")for i in range(10):        time.sleep(1)print("做了1个包子,分两半!")        c.send(i)        c2.send(i)producer("Alex")
 
©著作权归作者所有:来自51CTO博客作者天天打老虎的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. Python入门之迭代器与生成器的区别
  2. 报表生成器FastReport .Net如何使用FastReport.Service.dll?
  3. 分表分库后的id分配问题
  4. 一键生成前后端代码,Mybatis-Plus代码生成器让我舒服了
  5. 玩转可迭代对象迭代器生成器
  6. 报表生成器FastReport .Net如何存储和加载报告
  7. FastReport报表生成器有关COM / ActiveX快速报告
  8. .NET报表生成器Stimulsoft Reports.Net 常问问题解答
  9. Java 生成随机数的 5 种方式,你知道几种?

随机推荐

  1. 详解XML中Node和Element区别的示例代码
  2. Xml序列化的图文代码详解
  3. XML学习(三) js保存xml的示例代码分享
  4. XML串行化的示例代码分享
  5. 详细介绍XML操作总结的示例代码
  6. 使用xlst将xml转换html的示例代码
  7. XML实战秘籍第四卷:选单连动
  8. XML学习(二)详解DOM操作XML文档
  9. XML实战秘籍第三卷:动态分页
  10. XML学习(一)元素,属性,读取详解