上第一个实例:
def foo():
print("starting...")
yield 4
print(foo())
按照逻辑,应该输出starting, 但是实际上看下打印结果:
也就是说,这个函数根本不会执行
如何让这个函数执行呢?,看下个例子
def foo():
print("starting...")
yield 4
g = foo()
next(g)
原来需要调用next,才能正在让有yield的函数执行,那我们再调用一个next看下效果
def foo():
print("starting...")
yield 4
g = foo()
next(g)
next(g)
程序崩溃
再把上面的例子修改一下
def foo():
print("starting...")
yield 4
print("ending...")
yield 5
g = foo()
next(g)
next(g)
现在就不会崩溃了,输出如下:
***********************总结********************
含有yield的函数需要调用next才能执行,第一个next执行到函数的第一个yield位置,第二个next从第一个yield执行后面开始执行。
*****************************************************
再把例子修改一下
def foo():
print("starting...")
res =yield 4
print("ending...",res)
res =yield 5
g = foo()
print(next(g))
print(next(g))
看下输出结果:
为什么res为none呢?这里需要引入一个send函数,可以给res赋值,不然就一直未null
def foo():
print("starting...")
res =yield 4
print("ending...",res)
res =yield 5
g = foo()
g.send(None)
g.send(256)
send函数作用和next一样,但是可以发送一个值给res,第一次记得发送None。运行结果如下:
***************************再看一个例子********************************************
def foo():
print("starting...")
res =yield 4
print("ending...",res)
res =yield 5
for aa in foo():
print(aa)
输出结果如下:
我们会发现没有next和send,居然也能执行下去,是不是很神奇
这里如果是for 。。in 这种模式,会自动执行next直到运行结束。。记住即可。