博客
关于我
python之彻底搞懂迭代、可迭代、迭代器的区别(五)
阅读量:701 次
发布时间:2019-03-16

本文共 1070 字,大约阅读时间需要 3 分钟。

yield from从容器中取值

yield from从容器中取值,容器包含生成器,也就是说yield from让一个生成器将其部分操作委派给另外一个生成器。

def reverse(x):    while x-1>=0:        yield x-1        x -=1def list_number(x):    yield from range(x)    yield from range(x-1, -1, -1)    yield from reverse(x)for i in list_number(3):    print(i,end=',')out:0,1,2,2,1,0,2,1,0,

关于send方法的案例

def count():  # 子生成器,将yield传来的数字累加,若传来的值为None,则返回累加结果    result = 0    while 1:        x = yield        if x is None:            return result        result += xdef count_list(x):  # 父生成器,将累加任务委托给子生成器    while 1:        y = yield from count()        x.append(y)plus_list = []cal = count_list(plus_list)next(cal)  # 使生成器可以接收传入值for i in range(1, 5):    cal.send(i)cal.send(None)  # 实际收到None的是count函数,结束累加for i in range(1, 11):    cal.send(i)cal.send(None)  # 结束第二次累加print(plus_list)  # 输出最终结果out:[10, 55]

send方法两个注意点

  1. send方法要配合yield语句使用。
  2. send方法可以给yield传值,但yield尚未产生断点时传值会报错,所以先要对生成器执行一次next,然后才能正常传值。

深入理解send和yield from机制

send和yield from配合可以在调用者和生成器之间形成透明的双向数据通道,包括从生成器获取数据以及向生成器传送数据。

要更加深入理解send和yield机制需要学习和理解协程相关的知识点。留待日后梳理协程知识点时再细讲send和yield from。

转载地址:http://tnrqz.baihongyu.com/

你可能感兴趣的文章
NACOS部署,微服务框架之NACOS-单机、集群方式部署
查看>>
Nacos配置Mysql数据库
查看>>
Nacos配置中心中配置文件的创建、微服务读取nacos配置中心
查看>>
Nacos配置中心集群原理及源码分析
查看>>
nacos配置在代码中如何引用
查看>>
nacos配置新增不成功
查看>>
nacos配置自动刷新源码解析
查看>>
nacos集成分布式事务插件Seata的序列化问题,实际上是Seata本身存在bug!!
查看>>
Nacos集群搭建
查看>>
nacos集群搭建
查看>>
nacos集群网络分区对的影响和运维方式
查看>>
nacos集群节点故障对应用的影响以及应急方法
查看>>
nacos集群配置详解
查看>>
nagios 实时监控 iptables 状态
查看>>
nagios+cacti整合
查看>>
Nagios介绍
查看>>
nagios利用NSCient监控远程window主机
查看>>
nagios安装文档
查看>>
nagios服务端安装
查看>>
Nagios自定义监控脚本
查看>>