• 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('南京小笼包')
  • 相关阅读:
    TSQL 字符串前加 N 是什么意思
    SQL语句修改字段默认值
    Clustering Technologies On Windows Server 2008 R2
    sql 修改列名及表名
    Capture screenshots on Mac 在Mac下截图
    极限编程(XP,eXtreme Programming)
    zookeeper安装(单机版)
    linux备份用户权限
    Dubbo管控台安装(zookeeper单机版)
    linux查看IP
  • 原文地址:https://www.cnblogs.com/douyunpeng/p/12705385.html
Copyright © 2020-2023  润新知