浅谈 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

相关推荐
小成202303202651 天前
Linux高级02
linux·开发语言
知行合一。。。1 天前
Python--04--数据容器(总结)
开发语言·python
架构师老Y1 天前
008、容器化部署:Docker与Python应用打包
python·容器·架构
咸鱼2.01 天前
【java入门到放弃】需要背诵
java·开发语言
ZK_H1 天前
嵌入式c语言——关键字其6
c语言·开发语言·计算机网络·面试·职场和发展
A.A呐1 天前
【C++第二十九章】IO流
开发语言·c++
椰猫子1 天前
Java:异常(exception)
java·开发语言
lifewange1 天前
pytest-类中测试方法、多文件批量执行
开发语言·python·pytest
pluvium271 天前
记对 xonsh shell 的使用, 脚本编写, 迁移及调优
linux·python·shell·xonsh
cmpxr_1 天前
【C】原码和补码以及环形坐标取模算法
c语言·开发语言·算法