day10-协程遇到IO操作自动切换

本文介绍了Gevent这一轻量级协程库的基本使用方法及其实现并发的方式,并通过实例展示了如何利用Gevent来提高程序效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

  感觉确实用着比generator还简单了呢,但好像还没有解决一个问题,就是遇到IO操作,自动切换,对不对?所以我们接下来就说说如何遇到IO就切换,不得不提到一个模块Gevent。

  Gevent 是一个第三方库,可以轻松通过gevent实现并发同步或异步编程,在gevent中用到的主要模式是Greenlet, 它是以C扩展模块形式接入Python的轻量级协程。 Greenlet全部运行在主程序操作系统进程的内部,但它们被协作式地调度。

二、Gevent

2.1、代码

说明:gevent是第三方库,需要pip install一下

import  gevent

def foo():
    print("Running in foo")
    gevent.sleep(2)  #模仿io操作,一遇到io操作就切换
    print("Explicit context switch to foo again")

def bar():
    print("Explicit context to bar")
    gevent.sleep(1)
    print("Implicit context switch back to bar")

def fun3():
    print("running fun3")
    gevent.sleep(0)   #虽然是0秒,但是会触发一次切换
    print("running fun3 again")

gevent.joinall([
    gevent.spawn(foo),#生成协程
    gevent.spawn(bar),
    gevent.spawn(fun3)
])

注意:遇到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秒就执行完毕了。

转载于:https://www.cnblogs.com/zhangqigao/articles/7383927.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值