>>> def name_func():
... yield_result = 0
... while 1:
... yield_result += 1
... send_value = yield yield_result # 这一句是关键!!!
... print(f"func has been sent value : {send_value}")
...
>>>
>>> gen = name_func()
>>> # print(next(gen))
... print("yield_result : ", gen.send(None)) # 第一次调用, send 传入 None
yield_result : 1
>>> print("yield_result : ", gen.send("lavra"))
func has been sent value : lavra
yield_result : 2
>>> print("yield_result : ", gen.send("hiton"))
func has been sent value : hiton
yield_result : 3
上面的代码示例中,最关键的一句是:send_value = yield yield_result,其中:
-- send_value 是被 send 传入函数的值;
-- yield_result 是返回给调用方 gen 的值;
-
next 和 send 的区别:
-- next 只能取值;
-- send 能取本次yield的返回值,也能给上次yield传入值; -
send 注意点:
-- 第一个 send 不能给 yield 传值,必须要 send None,这一步不能省!
题就来,既然在给yield传值过程中,会调用next()方法,那么是不是在调用一次函数的时候,是不是每次都要给它传递一个空值?有没有什么简便方法来解决這个问题呢?答案,装饰器!!看下面代码:
分析:首先,我们要清楚,在函数执行之前,已经执行了一次next()(装饰器的功能),程序停止yield。接着程序往下执行,遇到g.send(),然后将其值传递给food,然后再将获得的food添加到列表food_list中。打印出food,再次循环程序停在yield。程序继续执行,又遇到g.send(),其过程与上面是一模一样的。