python 协程

协程之前我们明白Python的进程和线程,这里我们来说一下协程

  • 子程序切换不是线程切换,而是由程序自身控制
  • 没有线程切换的开销,和多线程比,线程数量越多,协程的性能优势就越明显
  • 不需要多线程的锁机制,因为只有一个线程,也不存在同时写变量冲突,在协程中控制共享资源不加锁
  • 协程实现

<code>def custumer():
r = ''
while True:
n = yield r # 接受send的值 返出yield的值
if not n:
return
print('custer {}'.format(n))
r = 'done'

def produce(c):
c.send(None) # 启动
n = 0
while n < 5:
n += 1
print('custer {}'.format(n))
r = c.send(n)
print('custer return {}'.format(r))
c.close()

c = custumer()
produce(c)/<code>


python 协程


分享到:


相關文章: