协程
- 代码实例如下:
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协作完成任务,所以称为“协程”,而非线程的抢占式多任务。
- 协程的好处:
最大的优势就是协程极高的执行效率。因为子程序切换不是线程切换,而是由程序自身控制,因此,没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显。 第二大优势就是不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁,只需要判断状态就好了,所以执行效率比多线程高很多。