python基础学习22----协程
2018-10-08 01:32:11来源:博客园 阅读 ()
协程,又称微线程。英文名Coroutine。
协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。
第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。
因为协程是一个线程执行,那怎么利用多核CPU呢?最简单的方法是多进程+协程,既充分利用多核,又充分发挥协程的高效率,可获得极高的性能。
进程相关请看https://www.cnblogs.com/sfencs-hcy/p/9744946.html
线程相关请看https://www.cnblogs.com/sfencs-hcy/p/9721362.html
1.yield实现的协程
def consumer(name): while True: bone = yield print("[%s] 正在使用 %s" % (name, bone)) def producer(obj1, obj2): obj1.send(None) obj2.send(None) n = 0 while n < 5: n += 1 print("[producer]正在生产 %s" % n) obj1.send(n) obj2.send(n) if __name__ == '__main__': con1 = consumer("consumerA") con2 = consumer("consumerB") producer(con1, con2)
2.greenlet实现协程
greenlet进行手动切换实现协程,切换的方式是switch
from greenlet import greenlet import time def producer(): while 1: print('生产一件商品') time.sleep(0.5) g2.switch() def consumer(): while 1: print('使用一件商品') time.sleep(0.5) g1.switch() g1 = greenlet(producer) #创建协程g1 g2 = greenlet(consumer) g1.switch()
3.Gevent实现协程
Gevent是一种基于协程的Python网络库,它用到Greenlet提供的,封装了libevent事件循环的高层同步API。它让开发者在不改变编程习惯的同时,用同步的方式写异步I/O的代码
import gevent def competitor1(): print("competitor1:我开始吃了") gevent.sleep(1) print("competitor1:我吃完了") def competitor2(): print("competitor2:我开始吃了") gevent.sleep(2) print("competitor2:我吃完了") gr1=gevent.spawn(competitor1) gr2=gevent.spawn(competitor2) gevent.joinall([gr1,gr2])
gevent.sleep()是模拟IO阻塞,如果所有子程序都进入IO阻塞则等待最先完成阻塞的子程序,之后进入该子程序执行。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:彻底弄懂python编码
下一篇:Python基础(中)
- python3基础之“术语表(2)” 2019-08-13
- python3 之 字符串编码小结(Unicode、utf-8、gbk、gb2312等 2019-08-13
- Python3安装impala 2019-08-13
- 小白如何入门 Python 爬虫? 2019-08-13
- python_字符串方法 2019-08-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash