python基础学习22----协程
2024-10-12 08:55:38
协程,又称微线程。英文名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阻塞则等待最先完成阻塞的子程序,之后进入该子程序执行。
最新文章
- AngularJS中Directive指令系列 - scope属性的使用
- 【HDU】4035 Maze
- linux 下查看系统资源和负载,以及性能监控
- CoreAnimation-04-核心动画必备基础
- CentOS安装NodeJS v0.10.25 + Express
- poj1266Cover an Arc(三角形外接圆)
- 单片机IO口驱动能力
- C#生成高清缩略图
- 关于android源码中的APP编译时引用隐藏的API出现的问题
- js超简单日历
- 党建凯,创新工场知乎团队Web前端工程师
- 深度学习基础网络 ResNet
- 洛谷 P5020 货币系统
- n&;m位运算
- PTA——求n以内k个质数和
- 《Windows核心编程》读书笔记 上
- [P3625][APIO2009]采油区域 (前缀和)
- 几种Bean的复制方法性能比较
- 转 功能强大的shell:if条件语句
- vue-transition-move
热门文章
- dig命令详解
- mysqldump 用法
- @JsonProperty和@JsonAlias的区别
- 怎样删除windows.old文件
- CruiseControl 安装配置
- 数据结构:IO读写频繁的青睐,B树和B+树
- NavicatForOracle无法连接数据库,报错ORA-28547
- 解决访问 jar 包里面的字体报错:OTS parsing error: incorrect file size in WOFF header
- C++11 使用 std::async创建异步程序
- MVC Helper Methods