day10-协程遇到 IO 操作自动切换
一、概述
感觉确实用着比generator还简单了呢,但好像还没有解决一个问题,就是遇到IO操作,自动切换,对不对?所以我们接下来就说说如何遇到IO就切换,不得不提到一个模块Gevent。
Gevent 是一个第三方库,可以轻松通过gevent实现并发同步或异步编程,在gevent中用到的主要模式是Greenlet, 它是以C扩展模块形式接入Python的轻量级协程。 Greenlet全部运行在主程序操作系统进程的内部,但它们被协作式地调度。
二、Gevent
2.1、代码
说明:gevent是第三方库,需要pip install一下
1 import gevent 2 3 def foo(): 4 print("running in foo") 5 gevent.sleep(2) #模拟IO操作 6 print("Explicit context switch to foo again") 7 8 def bar(): 9 print("explicit context to bar") 10 gevent.sleep(1) 11 print("Explicit context switch to bar again") 12 13 def fun3(): 14 print("runing fun3") 15 gevent.sleep(0) #虽然是0秒,但是也会触发操作 16 print("running fun3 again") 17 18 if __name__ == '__main__': 19 gevent.joinall([ 20 gevent.spawn(foo), 21 gevent.spawn(bar), 22 gevent.spawn(fun3) 23 ])
输出。。。
running in foo
explicit context to bar
runing fun3
running fun3 again
Explicit context switch to bar again
Explicit context switch to foo again
注意:遇到IO就切换了,整体程序还需要花2秒钟执行的,最长的就是2秒,如果是串行的话就是3秒。
2,2 、逻辑图

图解:
当foo遇到sleep(2)的时候,切自动切换到bar函数,执行遇到sleep(1)的时候自动切换到fun3函数,遇到sleep(0)又自动切换到foo。这个时候sleep(2)还没有执行完毕,又切换到bar的sleep(1)这边,发现又没有执行完毕,就有执行fun3这边,发现sleep(0)执行完毕,则继续执行,然后又切换到foo,发现sleep(2)又没有执行完毕,就切换到bar的sleep(1)这边,发现执行完了,有切回到foo这边,执行完毕。
三、用途
比如说你现在又50处IO,然后总共加起来串行的的话,要花100秒,但是50处IO最长的那个IO只花了5秒钟,那代表中你的这个程序就是协程最多5秒就执行完毕了。

浙公网安备 33010602011771号