专栏首页python3python基础学习22----协程

python基础学习22----协程

协程,又称微线程。英文名Coroutine。

协程最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。

第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。

因为协程是一个线程执行,那怎么利用多核CPU呢?最简单的方法是多进程+协程,既充分利用多核,又充分发挥协程的高效率,可获得极高的性能。

进程相关请看https://www.cnblogs.com/sfencs-hcy/p/9744946.html

线程相关请看https://www.cnblogs.com/sfencs-hcy/p/9721362.html

1.yield实现的协程

def consumer(name):

    while True:
        bone = yield
        print("[%s] 正在使用 %s" % (name, bone))

def producer(obj1, obj2):
    obj1.send(None)   
    obj2.send(None)   
    n = 0
    while n < 5:
        n += 1
        print("[producer]正在生产 %s" % n)
        obj1.send(n)
        obj2.send(n)

if __name__ == '__main__':
    con1 = consumer("consumerA")
    con2 = consumer("consumerB")
    producer(con1, con2)

2.greenlet实现协程

greenlet进行手动切换实现协程,切换的方式是switch

from greenlet import greenlet
import time

def producer():
    while 1:
        print('生产一件商品')
        time.sleep(0.5)
        g2.switch()

def consumer():
    while 1:
        print('使用一件商品')
        time.sleep(0.5)
        g1.switch()

g1 = greenlet(producer)  #创建协程g1
g2 = greenlet(consumer)

g1.switch()

3.Gevent实现协程

Gevent是一种基于协程的Python网络库,它用到Greenlet提供的,封装了libevent事件循环的高层同步API。它让开发者在不改变编程习惯的同时,用同步的方式写异步I/O的代码

import gevent

def competitor1():
    print("competitor1:我开始吃了")
    gevent.sleep(1)
    print("competitor1:我吃完了")

def competitor2():
    print("competitor2:我开始吃了")
    gevent.sleep(2)
    print("competitor2:我吃完了")

gr1=gevent.spawn(competitor1)
gr2=gevent.spawn(competitor2)

gevent.joinall([gr1,gr2])

gevent.sleep()是模拟IO阻塞,如果所有子程序都进入IO阻塞则等待最先完成阻塞的子程序,之后进入该子程序执行。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python之协程

      协程,又称微线程,纤程。英文名Coroutine。协程是一种用户态的轻量级线程。

    py3study
  • Python网络编程之协程

    与子例程一样,协程也是一种程序组件。 相对子例程而言,协程更为一般和灵活,但在实践中使用没有子例程那样广泛。 协程源自Simula和Modula-2语言,但也有...

    py3study
  • week02_python内置数据结构_

    round() :四舍六入,五取偶 floor():向下取整 ceil():向上取整 int():取整数部分,和//整除一样

    py3study
  • 装饰器实现用户验证登录

    在实现用户验证的登录的时候可以使用装饰器工厂产生装饰器,让装饰器得到参数,从而判断登录类型,并验证用户登录条件,代码实现如下:

    skylark
  • typescript叫anyscript?不存在的

    强烈建议使用vscode,因为都是同一家,对ts的支持和开发体验是非常棒的,大大增加了开发效率和质量,避免各种错误。

    lhyt
  • 并发编程-概述

    在早期的操作系统中,各个任务的执行完全是串行的,只有在一个任务运行完成之后,另一个任务才会被执行,我们称之为单道程序。

    Cool2Feel
  • [Python]函数的各种传参

    可以看出,在定义函数时,在参数前面加入一个*,就可以使得函数内部得到一个tuple数组。

    祥知道
  • TypeScript 疑难杂症

    作者:阿伟 - 身在高楼心在北大荒,我就这副死样~https://zhuanlan.zhihu.com/p/82459341

    ConardLi
  • java学习之stringbuffer和string之间的转换

    吾爱乐享
  • Flask中g对象,以及g,session,flash之间的区别

    注意:g对象比如说再a路由设置只能再a路由中去到g对象,在b路由汇总没法获得g对象

    小小咸鱼YwY

扫码关注云+社区

领取腾讯云代金券