Python并发编程:协程-greenlet模块

文章介绍了greenlet模块如何简化在单线程中处理多个任务的切换,对比了与生成器的方法。绿色let提供了更快的切换,但遇到IO操作时仍需手动切换。文中还提到了Gevent模块在处理既有计算又有阻塞操作的任务场景中的效率提升策略。
摘要由CSDN通过智能技术生成

一 greenlet模块

  如果我们在单个线程内有20个任务,要想实现在多个任务之间切换,使用yield生成器的方式过于麻烦(需要先得到初始化一次的生成器,然后再调用send。。。非常麻烦),而使用greenlet模块可以非常简单地实现这20个任务直接的切换

from greenlet import greenlet

def eat(name):

    print('%s eat 1' % name)

    g2.switch('mike')

    print('%s eat 2' % name)

    g2.switch()

def play(name):

    print('%s play 1' % name)

    g1.switch()

    print('%s play 2' % name)

g1 = greenlet(eat)

g2 = greenlet(play)

g1.switch('mike')   # 可以在第一次switch时传入参数,以后都不需要

单纯的切换(在没有io的情况下或者没有重复开辟内存空间的操作),反而降低程序的执行速度

# 顺序执行

import time

def f1():

    res = 1

    for in range(100):

        res += i

def f2():

    res = 1

    for in range(100):

        res *= i

start = time.time()

f1()

f2()

stop = time.time()

print('run time is %s' % (stop-start))  # 1.7881393432617

# 切换

from greenlet import greenlet

import time

def f1():

    res = 1

    for in range(100):

        res+=i

        g2.switch()

def f2():

    res = 1

    for in range(100):

        res*=i

        g1.switch()

start = time.time()

g1 = greenlet(f1)

g2 = greenlet(f2)

g1.switch()

stop = time.time()

print('run time is %s' %(stop-start))   # 8.5592269897460

greenlet只是提供了一种比generator更加快捷的切换方式,当切到一个任务执行时如果遇到io,那就原地阻塞,仍然是没有解决遇到io自动切换来提升效率的问题

  单线程里的这20个任务的代码通常会既有计算操作又有阻塞操作,完全可以在执行任务1时遇到阻塞,就利用阻塞的时间去执行任务2.。。如此,才能提高效率,这就用到了Gevent模块

  • 17
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值