时间:2021-05-22
一、yield运行方式
我们定义一个如下的生成器:
当我们把一个函数通过yield转换成生成器,直接运行函数是不会出现结果返回的。因为此时函数已经是个生成器了,我们要通过next()来取得值,并且在遇到yield时再次跳出函数。
print(type(p)) #输出<class 'generator'>我们添加next()方法:
def put_on(name): print("Hi {}, 货物来了,准备搬到仓库!".format(name)) while True: goods = yield #遇到yield中断 print("货物[%s]已经被%s搬进仓库了。"%(goods,name)) #中断后运行部分 p = put_on("bigberg")p.__next__() #输出Hi bigberg, 货物来了,准备搬到仓库!此时函数中断在 goods = yield 的地方,当我们再次调用next()函数时,函数只会运行中断以后的内容,即上例中的yield下面部分。
我们再添加一个next():
def put_on(name): print("Hi {}, 货物来了,准备搬到仓库!".format(name)) while True: goods = yield print("货物[%s]已经被%s搬进仓库了。"%(goods,name)) p = put_on("bigberg")p.__next__()p.__next__() #输出Hi bigberg, 货物来了,准备搬到仓库!货物[None]已经被bigberg搬进仓库了。我们可以第二次next()运行的是yield下面的部分内容,但是并没有给goods传值,所以货物是 None。
小结:
通过yield将函数转换为生成器,需要使用next()方法才能运行
yield只是保留函数的中断状态,再次调用next()会执行yield后面的部分
yield如果没有返回值,会返回一个None空值
二、send()传值
def put_on(name): print("Hi {}, 货物来了,准备搬到仓库!".format(name)) while True: goods = yield print("货物[%s]已经被%s搬进仓库了。"%(goods,name)) p = put_on("bigberg")p.__next__()p.send("瓜子") #输出Hi bigberg, 货物来了,准备搬到仓库!货物[瓜子]已经被bigberg搬进仓库了。小结:
__next__()只是调用这个yield,也可以说成是唤醒yield,但是不不会给yield传值。
send()方法调用yield是,能给yield传值
使用send()函数之前必须使用__next__(),因为先要中断,当第二次调用时,才可传值。
def put_on(name): print("Hi {}, 货物来了,准备搬到仓库!".format(name)) while True: goods = yield print("货物[%s]已经被%s搬进仓库了。"%(goods,name)) p = put_on("bigberg")p.__next__()p.send("瓜子")p.send("花生")p.send("饼干")p.send("牛奶") #多次调用send()Hi bigberg, 货物来了,准备搬到仓库!货物[瓜子]已经被bigberg搬进仓库了。货物[花生]已经被bigberg搬进仓库了。货物[饼干]已经被bigberg搬进仓库了。货物[牛奶]已经被bigberg搬进仓库了。三、单线程实现并行效果(协程)
import time def put_on(name): print("Hi {}, 货物来了,准备搬到仓库!".format(name)) while True: goods = yield print("货物[%s]已经被%s搬进仓库了。"%(goods,name)) def transfer(name): p = put_on('A') p2 = put_on('B') p.__next__() p2.__next__() print("%s将货物送来了!"%name) for i in range(5): time.sleep(1) print("%s递过来两件货物"%name) p.send("瓜子") p2.send("花生") transfer("bigberg") #输出Hi A, 货物来了,准备搬到仓库!Hi B, 货物来了,准备搬到仓库!bigberg将货物送来了!bigberg递过来两件货物货物[瓜子]已经被A搬进仓库了。货物[花生]已经被B搬进仓库了。bigberg递过来两件货物货物[瓜子]已经被A搬进仓库了。货物[花生]已经被B搬进仓库了。bigberg递过来两件货物货物[瓜子]已经被A搬进仓库了。货物[花生]已经被B搬进仓库了。bigberg递过来两件货物货物[瓜子]已经被A搬进仓库了。货物[花生]已经被B搬进仓库了。bigberg递过来两件货物货物[瓜子]已经被A搬进仓库了。货物[花生]已经被B搬进仓库了。以上这篇python 生成器协程运算实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了python生成器/yield协程/gevent写简单的图片下载器功能。分享给大家供大家参考,具体如下:1、生成器:'''第二种生成器'''#函数
问题你想使用生成器(协程)替代系统线程来实现并发。这个有时又被称为用户级线程或绿色线程。解决方案要使用生成器实现自己的并发,你首先要对生成器函数和yield语句
这篇文章是读者朋友的python协程的学习经验之谈,以下是全部内容:协程的历史说来话长,要从生成器开始讲起。如果你看过我之前的文章python奇遇记:迭代器和生
前言从语法上来看,协程和生成器类似,都是定义体中包含yield关键字的函数。yield在协程中的用法:在协程中yield通常出现在表达式的右边,例如:datum
生成器就是自己用python代码写的迭代器,生成器的本质就是迭代器。通过以下两种方式构建一个生成器:1、通过生成器函数2、生成器表达式生成器函数:函数deffu