【python Greenlet多任务并发 】

gevent 一个基于 Greenlet 库的并发库

gevent 是一个基于 Greenlet 库的并发库

gevent 是一个基于 Greenlet 库的并发库,它提供了更高级的接口以及对网络操作的特殊处理。gevent 提供了一种在 Python 中简单有效地处理并发的方法。

import gevent,time
from gevent import monkey

# 把下面这句放在脚本的开头
monkey.patch_all()  # 把IO操作转为gevent的异步执行

def worker(n, m):
    for i in range(m):
        print('Worker', n, 'runng', i)
        # 模拟 IO 操作,如网络请求
        time.sleep(1)  

# 创建并启动协程
gevent.joinall([
    gevent.spawn(worker, 'A', 5),
    gevent.spawn(worker, 'B', 5),
    gevent.spawn(worker, 'C', 5),
])

这例子,创建了三个协程,每个协程都执行 worker 函数,但是传入的参数不同。gevent.spawn 创建一个新的 Greenlet 协程,然后 gevent.joinall 等待所有协程完成。

值得注意的是,gevent.sleep 不仅仅是一个暂停执行的函数,它也会触发 gevent 进行上下文切换,让其他协程有机会运行。这就是为什么我们在 worker 函数中使用 gevent.sleep 的原因。

monkey.patch_all() 是一个重要的函数,它会修改标准库中的某些函数,使得它们变为协作式运行,这样就可以在 gevent 中使用了。例如,如果你在协程中使用 time.sleep,那么整个进程都会被阻塞,而如果使用 gevent.sleep,只有当前协程会被阻塞,其他协程可以继续运行。通过 monkey.patch_all(),你可以把 gevent.sleep替换为 time.sleep ,这样在代码中就可以直接使用 time.sleep 了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值