浅谈 Python 中的 yield——生成器对象与函数调用的区别

我们来看这么一个例子:

python 复制代码
def greeter():
    name = yield "你是谁?"
    yield f"你好,{name}"

g = greeter()
print(next(g))        # → "你是谁?"
print(g.send("张三")) # → "你好,张三"

执行流程:

复制代码
next(g):执行到 yield,返回 "你是谁?";

send("张三"):将 "张三" 送入上次 yield 表达式的返回值,继续执行。

send() 是构建协程通信、任务调度器的核心机制之一(如 asyncio、trio、LangGraph 内核)。

g = greeter()是greeter() 执行的结果赋值给 g这个结果是一个生成器对象(generator) ,而不是把函数本身赋值给 g


🔍 详细分析

当我们写:

python 复制代码
def greeter():
    name = yield "你是谁?"
    yield f"你好,{name}"

此时,greeter 是一个函数对象(还没执行)。

当我们调用 greeter()

python 复制代码
g = greeter()

Python 会:

  • 执行函数定义,但并不运行函数体
  • 因为函数中含有 yield,所以它会返回一个 生成器对象 ,即 g 是一个 generator

我们可以验证:

python 复制代码
print(type(g))  # <class 'generator'>

这就意味着:

python 复制代码
g = greeter()  # g 现在是生成器对象,不是函数本身

✅ 所以两种情况的对比:

写法 含义 类型
g = greeter 把函数本身赋值给变量 g,不执行 <function>
g = greeter() 执行函数,返回一个生成器对象 <generator>

✅ 举个例子验证一下

python 复制代码
def example():
    yield 42

print(example)      # <function example at 0x...>
print(example())    # <generator object example at 0x...>

✅ 总结

greeter() 是函数调用表达式,执行时返回一个生成器对象 ;所以 g = greeter() 是在 将生成器对象赋值给 g ,而不是将函数本身赋值给 g

相关推荐
IVEN_11 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang13 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮13 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling13 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮16 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽16 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健1 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞1 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽1 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers