博客
关于我
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/

你可能感兴趣的文章
Netty中的组件是怎么交互的?
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
netty之 定长数据流处理数据粘包问题
查看>>
Netty事件注册机制深入解析
查看>>
netty代理
查看>>
Netty入门使用
查看>>
netty入门,入门代码执行流程,netty主要组件的理解
查看>>
Netty原理分析及实战(一)-同步阻塞模型(BIO)
查看>>
Netty原理分析及实战(三)-高可用服务端搭建
查看>>
Netty原理分析及实战(二)-同步非阻塞模型(NIO)
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty发送JSON格式字符串数据
查看>>
Netty和Tomcat的区别已经性能对比
查看>>
Netty在IDEA中搭建HelloWorld服务端并对Netty执行流程与重要组件进行介绍
查看>>
Netty基础—1.网络编程基础一
查看>>
Netty基础—1.网络编程基础二
查看>>
Netty基础—2.网络编程基础三
查看>>
Netty基础—2.网络编程基础四
查看>>
Netty基础—3.基础网络协议一
查看>>
Netty基础—3.基础网络协议二
查看>>