时间:2021-05-22
这篇文章是读者朋友的python协程的学习经验之谈,以下是全部内容:
协程的历史说来话长,要从生成器开始讲起。
如果你看过我之前的文章python奇遇记:迭代器和生成器 ,对生成器的概念应该很了解。生成器节省内存,用的时候才生成结果。
# 生成器表达式a = (x*x for x in range(10))# next生成值next(a()) # 输出0next(a()) # 输出1next(a()) # 输出4与生成器产出数据不同的是,协程在产出数据的同时还可以接收数据,具体来说就是把yield 放在了表达式的右边。我们可以使用.send() 把数据发送给协程函数。
def writer(): print('-> coroutine started') for i in range(8): w = yield print(i+w)w = writer()# 本质还是生成器>>> w<generator object writer at 0x000002595BC57468># 首先要用next()把协程激活>>> next(w)-> coroutine started# 发送数据>>> w.send(1)1# send到第八次之后会抛出异常# 因为协程已经结束了---------------------------------------------------------------------------StopIteration Traceback (most recent call last)第一步必须使用next() 激活协程函数,这样才能在下一步使用.send() 发送数据。
可以看到,在第8次接收完数据之后,会产生结束的异常,因为程序流程结束了,这是正常现象。加个异常处理即可。如果需要在两个协程间传递数据呢?
def writer(): while True: w = yield print('>>', w)def writer_wrapper(coro): # 激活 next(coro) while True: # 异常处理 try: x = yield # 发送数据给writer coro.send(x) except StopIteration: passw = writer()wrap = writer_wrapper(w)# 激活next(wrap)for i in range(4): wrap.send(i)# 输出>> 0>> 1>> 2>> 3上面的代码中,数据首先传递到writer_wrapper,之后再传递到writer 。
data——>writer_wrapper——>writer
可以这么写,不过,又要预先激活,又要加异常,看起来有点麻烦啊。yield from 的出现可以解决这个问题,同样是传递数据:
def writer(): while True: w = yield print('>>', w)def writer_wrapper2(coro): yield from coro一行代码解决问题。
总之,yield from相当于提供了一个通道,使得数据可以在协程之间流转 。writer_wrapper2 中使用yield from coro时,coro此时获得控制权,在我们.send() 数据时,writer_wrapper2 被阻塞,直到writer 打印出结果。
在这个阶段,协程本质上还是由生成器构成的。
即使我们使用yield from 简化了流程,协程和生成器的知识理解起来还是有点懵逼,而且yield from 用在异步编程中有诸多不顺(asyncio以前就是用yield from),于是在3.5版本的python中,弃用了yield from ,新加入了两个关键字async 和await ,同时协程不再是生成器类型,而是原生的协程类型。
现在我们定义一个协程要像下面这样:
async def func(): await 'some code'不用于异步的协程该怎么用,我还不知道。所以,协程的介绍到这里就结束啦。感谢你对的支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Python协程yield与协程greenlet简单用法。分享给大家供大家参考,具体如下:协程协程,又称微线程,纤程。英文名Coroutine。协
前言相信大家都听说过『协程』这个概念吧。但是有些同学对这个概念似懂非懂,不知道怎么实现,怎么用,用在哪,甚至有些人认为yield就是协程!我始终相信,如果你无法
python协程线程和进程的操作是由程序触发系统接口,最后的执行者是系统;协程的操作则是程序员。协程存在的意义:对于多线程应用,CPU通过切片的方式来切换线程间
Python通过yield提供了对协程的基本支持,但是不完全。而第三方的gevent为Python提供了比较完善的协程支持。gevent是第三方库,通过gree
协程,又称微线程,纤程。英文名Coroutine。协程是Python中另外一种实现多任务的方式,只不过比线程更小,占用更小执行单元(理解为需要的资源)。为啥说它