当前位置: 首页 > news >正文

14.examples\01-Micropython-Basics\demo_yield.py 加强版

demo_yield.py 程序主要演示了microPython中生成器(Generator)的使用,特别是通过yield语句进行双向通信的机制(既能产出值也能接收值),以及控制流的暂停和恢复机制。

常见的普通 return 函数会立即返回所有结果,而使用 yield 的函数会在每次迭代时逐步产生结果。

def event():print('start yield')# return next(task) and yield next(task.send('set_two'))one = yield 'get_one'assert(one == 'set_two')print(one)yield 'get_two'  # return next(task) and yield next(task.send('set_two'))print('exit yield')yield  # yield next() to exit or raise StopIterationtask = event()
run_one = next(task)  # need next(task) init and next(task) == task.send(None)
# so next(task) => yield 'get_one' => run_one = 'get_one'
assert(run_one == 'get_one')
run_two = task.send('set_two')
assert(run_two == 'get_two')
print('run : ', run_one, ' and ', run_two)try:next(task)print('run end')next(task)  # will raise StopIteration
except Exception as e:print('yield StopIteration')if __name__ == '__main__':def task():while True:print('hello')yieldtmp = task()while True:next(tmp)while True:print('hello')

当不做任何修改,执行示例程序时,实际输出结果只有循环的 hello。

让我们来修改以下,注释掉if __name__ == '__main__':这句及以后面的程序,再运行一下:

def event():# event函数是一个生成器函数,因为它包含yield语句。当调用event()时,它会返回一个生成器对象,而不会立即执行函数体内的代码。print('start yield')# return next(task) and yield next(task.send('set_two'))one = yield 'get_one'# 第一次暂停,返回'get_one'assert(one == 'set_two')# 验证传入的值print(one)# 打印接收到的值yield 'get_two'  # # 第二次暂停,返回'get_two'   return next(task) and yield next(task.send('set_two'))print('exit yield')yield  # yield next() to exit or raise StopIteration  # 最后一次暂停,返回None#这个函数包含三个yield语句,每次执行到yield时会暂停并返回一个值。task = event()#创建生成器对象(此时函数并未执行)
run_one = next(task)  ## 启动生成器,执行到第一个yield处暂停    need next(task) init and next(task) == task.send(None)
# so next(task) => yield 'get_one' => run_one = 'get_one'
assert(run_one == 'get_one')
run_two = task.send('set_two')# 发送值'set_two'到生成器,恢复执行
assert(run_two == 'get_two')
print('run : ', run_one, ' and ', run_two)try:next(task)print('run end')next(task)  # will raise StopIteration
except Exception as e:print('yield StopIteration')#if __name__ == '__main__':#    def task():
#        while True:
#            print('hello')
#            yield#    tmp = task()
#    while True:
#        next(tmp)#    while True:
#        print('hello')

修改后的程序运行结果如下:

yield 是定义 生成器函数(generator function) 的关键字。通过以上程序也可以看出来:yield 的作用就是把一个函数变成一个 生成器 generator,带有 yield 的函数Python 解释器会将其认为是一个生成器 generator,函数内部的代码执行到 yield时,函数就返回一个迭代值,下次迭代时,代码从 yield 的下一条语句继续执行,直到再次遇到 yield。

    1. 调用生成器函数不会立即执行,而是返回一个生成器对象。

    2. 必须使用next()send(参数)启动生成器。

    3. 当需要逐个返回大量数据项时,优先使用 yield,可以很好的节约内存使用量

    4. 在构建数据处理流水线时,结合 yield 和函数组合可进行高效的处理。

    start yield
    set_two
    run :  get_one  and  get_two
    exit yield
    run end
    yield StopIteration
    MPY: soft reboot
    CanMV v1.3-132-gb19c756(based on Micropython e00a144) on 2025-08-09; k230_canmv_01studio with K230

    结合每步的输出,加详细注释如下:

    def event():# event函数是一个生成器函数,因为它包含yield语句。当调用event()时,它会返回一个生成器对象,而不会立即执行函数体内的代码。print('start yield')# return next(task) and yield next(task.send('set_two'))one = yield 'get_one'# 第一次暂停,返回'get_one'assert(one == 'set_two')# 验证传入的值print(one)# 打印接收到的值yield 'get_two'  # # 第二次暂停,返回'get_two'   return next(task) and yield next(task.send('set_two'))print('exit yield')yield  # yield next() to exit or raise StopIteration  # 最后一次暂停,返回None#这个函数包含三个yield语句,每次执行到yield时会暂停并返回一个值。task = event()#创建生成器对象(此时函数并未执行)
    run_one = next(task)  # 实际输出:start yield  (启动生成器,执行到第一个yield处暂停    need next(task) init and next(task) == task.send(None))
    print(run_one)#实际输出:get_one
    ## so next(task) => yield 'get_one' => run_one = 'get_one'
    assert(run_one == 'get_one')
    run_two = task.send('set_two')# 发送值'set_two'到生成器,恢复执行
    print(run_two)#实际输出:get_two
    assert(run_two == 'get_two')
    print('run : ', run_one, ' and ', run_two)try:next(task)print('run end')next(task)  # will raise StopIteration
    except Exception as e:print('yield StopIteration')#====================================================
    实际输出结果::start yield
    get_one
    set_two
    get_two
    run :  get_one  and  get_two
    exit yield
    run end
    yield StopIteration
    MPY: soft reboot
    CanMV v1.3-132-gb19c756(based on Micropython e00a144) on 2025-08-09; k230_canmv_01studio with K230

    http://www.dtcms.com/a/350036.html

    相关文章:

  • 深入浅出 ArrayList:从基础用法到底层原理的全面解析(中)
  • 深度剖析 Grok2 开源:技术原理与创新洞察
  • 奶茶品牌ESG实践:从绿色供应链到可持续竞争力
  • 离线可用的网络急救方案
  • [RK3568][Android11] Android->默认显示设置->系统->开发者选项(不用连续点击版本号)
  • FunASR基础语音识别工具包
  • 学习Python第13天
  • .NET表格控件Spread .NET v18.0——支持富文本、增强PDF导出
  • 【Linux基础知识系列】第一百零七篇 - 使用crontab设置定期任务
  • 【文献阅读】SparseGPT: Massive Language Models Can be Accurately Pruned in One-Shot
  • 【保姆级】AutoCAD 2026安装包下载及详细图文安装教程!
  • Mysql杂志(一)
  • 大模型中常用的提示词框架
  • Python爬虫第五课:selenium自动化爬虫实战
  • ICCV 2025|TRACE:无需标注,用3D高斯直接学习物理参数,从视频“预知”未来!
  • 从2D序列帧到3D体积感:我用AE+UE5 Niagara构建次世代风格化VFX工作流
  • AWS ECS 成本优化完整指南:从分析到实施的最佳实践
  • 嵌入式第三十七天(TCP补充,应用层协议(HTTP))
  • 物联网时序数据库IoTDB架构解析
  • 告别“复制粘贴”式换肤:我用Adobe XD组件变体与CC库,构建多品牌设计系统架构
  • Android用Coil 3检查媒体资源是否有效,Kotlin
  • 【Github】Windows原始hosts文件内容及加速访问Github的方法
  • Linux系统操作编程——http
  • Zabbix Vs. Grafana
  • 在压力测试中如何确定合适的并发用户数?
  • ASP.NET Core 中的构建者模式
  • uniapp中加载.urdf后缀的3D模型(three.js+urdf-loader)
  • 灰狼算法+四模型对比!GWO-CNN-BiLSTM-Attention系列四模型多变量时序预测
  • day62 Floyd 算法 A * 算法
  • 【GPT入门】第58课 感性认识Imdeploy介绍与实践