说明:python中的协程是通过生成器来实现的,yield不仅能返回值,同时也能接收参数,实现协程之间的通信。
'''
协程:也叫微线程或者子程序,协程是运行在线程中的,因为单线程不存在同时修改变量的冲突,
因此协程无需加锁,也就是没有锁机制。
协程相对于线程也不需要线程切换的资源浪费的情况,相对来说协程更加高效。
在多核的模式下,由于python的GIL,规定了python程序实际还是单线程的运行模式,所以
多进程+协程要比多进程+多线程更加高效
'''
def consumer():
r = ''
while True:
n = yield r
if not n:
return
print('[CONSUMER] Consuming %s...' % n)
r = '200 OK'
def produce(c):
c.send(None)
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()
c = consumer()
produce(c)
执行结果:
[PRODUCER] Producing 1...
[CONSUMER] Consuming 1...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 2...
[CONSUMER] Consuming 2...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 3...
[CONSUMER] Consuming 3...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 4...
[CONSUMER] Consuming 4...
[PRODUCER] Consumer return: 200 OK
[PRODUCER] Producing 5...
[CONSUMER] Consuming 5...
[PRODUCER] Consumer return: 200 OK