Python的yield协程机制实现生产者-消费者模式
2016-05-03 14:59
615 查看
利用yield的协程机制我们可以轻松地实现生产者-消费者模式:
协程执行流程:
1.创建协程对象(也就是消费者)后,必须使用send(None)或next()启动;
2.协程在执行yield后让出执行绪,等待消息;
3.调用方发送send(1)消息,协程恢复执行,将接收到的数据保存到d,执行后续流程;
4.再次循环到yield,协程返回前面的处理结果,并再次让出执行绪;
5.直到关闭或被引发异常。
#-*- coding:utf-8 -*- def consumer(): while True: d=yield if not d: break print "consumer:",d c=consumer() #创建消费者 c.send(None) #启动消费者 c.send(1) #生产数据,并提交给消费者,运行结果:consumer:1 c.send(2) c.send(None) #生产结束,通知消费者结束,抛出StopIteration异常。
协程执行流程:
1.创建协程对象(也就是消费者)后,必须使用send(None)或next()启动;
2.协程在执行yield后让出执行绪,等待消息;
3.调用方发送send(1)消息,协程恢复执行,将接收到的数据保存到d,执行后续流程;
4.再次循环到yield,协程返回前面的处理结果,并再次让出执行绪;
5.直到关闭或被引发异常。
相关文章推荐
- Python动态类型的学习---引用的理解
- Python3写爬虫(四)多线程实现数据爬取
- 垃圾邮件过滤器 python简单实现
- 下载并遍历 names.txt 文件,输出长度最长的回文人名。
- install and upgrade scrapy
- Scrapy的架构介绍
- Centos6 编译安装Python
- 使用Python生成Excel格式的图片
- 让Python文件也可以当bat文件运行
- [Python]推算数独
- Python中zip()函数用法举例
- Python中map()函数浅析
- Python将excel导入到mysql中
- Python在CAM软件Genesis2000中的应用
- 使用Shiboken为C++和Qt库创建Python绑定
- FREEBASIC 编译可被python调用的dll函数示例
- Python 七步捉虫法