如果send不携带参数,那么send(None) 和next()的作用的相同的,如:
def a(): print('aaa') p = yield '123' #print(p) print('bbb') r = a() print(next(r)) #print(r.send(None)) #使用next(r) 和 r.send(None)输出的结果都是 #注意的是,这里的p变量的值都是None aaa 123
如果send的参数不是None,则是把yield xx当成一个表代式,且把send的参数的值赋给了p;而后的操作同next一样,如:
def a(): print('aaa') p1 = yield '123' print('bbb') if (p1 == 'hello'): print('p1是send传过来的') p2= yield '234' print(p2) r = a()#r是一个生成器 next(r)#执行了next(r)但是并没有打印返回值,如果是print(next(r))则打印结果第二行是123 r.send('hello')#send(‘hello’)传递给p1 #结果为 aaa bbb p1是send传过来的
说一下执行的顺序,首先a()是个生成器;第一次执行要么next(r)要么r.send(None),不能使用r.send('xxxxx');这会报错的。第一次执行时next(r)时,首先打印出aaa,
然后遇到yield即跳出,然后执行r.send('hello')时,p1则被赋值为hello了,然后继续接着上次运行,下一步打印出bbb,然后打印出'p1是send传过来的',当再次遇到第二个yield时跳出,所以结果只打印了三行,后面的p2没有执行。
生产者消费者模型
import time#导入时间工具 def customer(name2):#定义一个顾客的函数 print('%s准备吃包子了'%name2) while True:#如果没有while,不能循环执行第一个函数 baozi = yield 1#创建一个生成器 print('包子%s来了,被%s吃了!'%(baozi,name2)) def producer(name1):#创建一个生产者的函数 c1 = customer('小王')#将顾客函数赋值给c1 c1.__next__()#c1调用next功能 print('开始准备做包子') for i in range(5): time.sleep(1) c1.send(i)#将生产好的i send生成器 producer('南京小笼包')