协程原理代码演示

复制代码
'''
协程原理演示
'''
def consumer():
r=''
while True:
n=yield r
if not n:
return
print('【消费者】正在消费 %s 中...'%n)
r='OK,完成消费!!'

def produce(c):
c.send(None)
n=0
while n<5:
n+=1
print('【生产者】正在生产 %s 中......'%n)
r=c.send(n)
print('【生产者】消费者返回了:%s !'%r)
c.close()

c=consumer()
produce(c)
复制代码

'''

【生产者】正在生产 1 中......
【消费者】正在消费 1 中...
【生产者】消费者返回了:OK,完成消费!! !
【生产者】正在生产 2 中......
【消费者】正在消费 2 中...
【生产者】消费者返回了:OK,完成消费!! !
【生产者】正在生产 3 中......
【消费者】正在消费 3 中...
【生产者】消费者返回了:OK,完成消费!! !
【生产者】正在生产 4 中......
【消费者】正在消费 4 中...
【生产者】消费者返回了:OK,完成消费!! !
【生产者】正在生产 5 中......
【消费者】正在消费 5 中...
【生产者】消费者返回了:OK,完成消费!! !

注意到consumer函数是一个generator,把一个consumer传入produce后:

首先调用c.send(None)启动生成器;

然后,一旦生产了东西,通过c.send(n)切换到consumer执行;

consumer通过yield拿到消息,处理,又通过yield把结果传回;

produce拿到consumer处理的结果,继续生产下一条消息;

produce决定不生产了,通过c.close()关闭consumer,整个过程结束。

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

最后套用Donald Knuth的一句话总结协程的特点:“子程序就是协程的一种特例。”

'''

posted @   晨光曦微  阅读(279)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示