python  协程

子程序或者说函数之间的相互嵌套调用是通过栈来实现的,一个线程就是执行一个子程序,子程序调用总是一个入口对应一次返回,调用的顺序是事先确定的,在一个子程序的执行过程中不能中断去执行其他子程序,而协程则可以在子程序内部中断(类似cpu的中段机制)转而去执行其他子程序(⚠️不是函数调用),在适当的时候再返回执行。

协程的特点是一个线程运行,和多线程比协程的优势在哪里?

1 没有切换线程时的开销;

2 因为时在一个线程里运行,所以不需要‘锁’同步协程;

我们改用协程来实现经典的生产者消费者模式:

>>> 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...
>>> 

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

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

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

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

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

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

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

最后套用Donald Knuth的一句话总结协程的特点:

“子程序就是协程的一种特例。”

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值