python协程
协程
协程是python个中另外⼀种实现多任务的⽅式,只不过⽐线程更⼩占⽤更⼩执⾏单元(理解为需要的资源)。 为啥说它是⼀个执⾏单元,因为它⾃带CPU上下⽂。这样只要在合适的时机, 我们可以把⼀个协程 切换到另⼀个协程。 只要这个过程中保存或恢复 CPU上下⽂那么程序还是可以运⾏的。
通俗的理解:在⼀个线程中的某个函数,可以在任何地⽅保存当前函数的⼀些临时变量等信息,然后切换到另外⼀个函数中执⾏,注意不是通过调⽤函数的⽅式做到的,并且切换的次数以及什么时候再切换到原来的函数都由开发者⾃⼰确定。
greenlet
为了更好使⽤协程来完成多任务,python中的greenlet模块对其封装,从⽽使得切换任务变的更加简单。
- python中添加gevent模块的方式:pip3 install gevent
- gevent的用法:遇到延时操作,就切换线程
- 注意gevent使用时需要gevent.time延时/join()等待完成
语法实现示例
1.简单多任务:
import gevent
import time
from gevent import monkey
monkey.patch_all()
def f1(n):
for i in range(n):
print(gevent.getcurrent(), i)
time.sleep(0.5)
def f2(n):
for i in range(n):
print(gevent.getcurrent(), i)
time.sleep(0.5)
def f3(n):
for i in range(n):
print(gevent.getcurrent(), i)


1074

被折叠的 条评论
为什么被折叠?



