协程
协程,又叫做微线程,纤程。
子程序,或者叫函数,在所有的语言中都是层级的调用,比如A调B,B在执行的过程中又调用了C,C执行完毕返回,B执行完毕返回,最后A执行完毕。所以子程序的调用是通过栈实现的,一个线程就是执行一个子程序。
协程看上去也是子程序,但是在执行过程中,在子程序的内部是可以中断的,然后去执行别的子程序,在适当的时候再返回来接着执行。
注意:在一个子程序中中断,去执行其他的子程序,不是函数调用,有点类似CPU中断。
把生产者和消费者改成协程
import time
def consumer():
r = ''
while True:
n = yield r
if not n:
return
print('[CONSUMER] Consuming %s...' % n)
time.sleep(1)
r = '200 OK'
def produce(c):
c.next()
n = 0
while n < 5:
n = n + 1
print('[PRODUCER] Producing %s...' % n)
r = c.send(n)
print('[PRODUCER] Consumer return: %s' % r)
c.close()
if __name__=='__main__':
c = consumer()
produce(c)
协程优点
协程最大的优点就是协程极高的执行效率。因为子程序的切换不是线程切换,而是由程序自身控制,因此没有线程切换的开销,和多线程比,线程的数量越多,协程的性能越好。
协程的第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。