3-31

170 阅读1分钟

协程

  • 代码实例如下:
def consumer():
    r = ''
    while True:
        n = yield r   # n 的值就是send的值
        if not n:
            return
        print('[CONSUMER] Consuming %s...' % n)
        r = '200 OK'    # product的r

def produce(c):
    c.send(None)   # 发向生成器 None
    n = 0
    while n < 5:
        n = n + 1
        print('[PRODUCER] Producing %s...' % n)
        r = c.send(n)   # 发向生成器 n
        print('[PRODUCER] Consumer return: %s' % r)
    c.close()

c = consumer()  #一个生成器
produce(c)

整个流程无锁,由一个线程执行,produce和consumer协作完成任务,所以称为“协程”,而非线程的抢占式多任务。

  • 协程的好处:

最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。 第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。

重点:一个核,无线程切换,所以快