python3 yield表达式形式应用

时间:2021-09-26 23:31:33
我们已知:
  生成器函数:函数体内包含有yield关键字,该函数执行的结果是生成器
yield的功能:
  1.与return类似,都可以返回值,但不一样的地方在于yield返回多次值,而return只能返回一次值
  2.为函数封装好了__iter__和__next__方法,把函数的执行结果做成了迭代器
  3.遵循迭代器的取值方式obj.__next__(),触发的函数的执行,函数暂停与再继续的状态都是由yield保存的

yield的表达式:
  x = yield  将yield的值传给x,那么yield的值哪里来?用send( )传入
send的效果:
  1:先从为暂停位置的那个yield传一个值,然后yield会把值赋值x
  2:与next的功能一样
 
def init(func):    # 此装饰器给foo()函数做初始化,next(g)停留在yield。
def wrapper(*args,**kwargs):
g=func(*args,**kwargs)
next(g)
return g
return wrapper

@init #foo=init(foo)
def foo():
print('starting')
while True:
x=yield None#return 1
print('value : ',x)

g=foo() #wrapper()

g.send(2)  # 然后用g.send(2)传值给yield,执行顺序为:send()传值给yield,yield传值给x,然后执行next()的功能。

练习: 食客吃饭上菜
def init(func):
def wrapper(*args, **kwargs):
g = func(*args,**kwargs)
next(g)
return g
return wrapper

@init
def eater(name):
print('%s start to eat' %name)
food_list= []
while True:
food=yield food_list
food_list.append(food)
print('%s start to eat %s' %(name, food))

def make_food(people,n):
for i in range(n):
people.send('food%s' %i)

e = eater('alex')
make_food(e,5)