day19 生产者模型-next与send用法详解-生产者消费者模型

如果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('南京小笼包')

 

posted @ 2020-04-15 15:02  窦云鹏  阅读(190)  评论(0编辑  收藏  举报