生成器对象

生成器对象是Python用来实现生成器迭代器的对象。它们通常通过迭代产生值的函数来创建,而不是显式调用 PyGen_New()PyGen_NewWithQualName()

type PyGenObject

用于生成器对象的C结构体。

PyTypeObject PyGen_Type

与生成器对象对应的类型对​​象。

int PyGen_Check(PyObject *ob)

如果 ob 是一个 generator 对象则返回真值;ob 必须不为 NULL。 此函数总是会成功执行。

int PyGen_CheckExact(PyObject *ob)

如果 ob 的类型是 PyGen_Type 则返回真值;ob 必须不为 NULL。 此函数总是会成功执行。

PyObject *PyGen_New(PyFrameObject *frame)
返回值:新的引用。

基于 frame 对象创建并返回一个新的生成器对象。 此函数会取走一个对 frame 的引用。 参数必须不为 NULL

PyObject *PyGen_NewWithQualName(PyFrameObject *frame, PyObject *name, PyObject *qualname)
返回值:新的引用。

基于 frame 对象创建并返回一个新的生成器对象,其中 __name____qualname__ 设为 namequalname。 此函数会取走一个对 frame 的引用。 frame 参数必须不为 NULL

PyCodeObject *PyGen_GetCode(PyGenObject *gen)

返回一个新的指向 gen 所包装的代码对象的 strong reference。 此函数总是会成功执行。

异步生成器对象

参见

PEP 525

PyTypeObject PyAsyncGen_Type

对应异步生成器对象的类型对象。 它在 Python 层面上为 types.AsyncGeneratorType

Added in version 3.6.

PyObject *PyAsyncGen_New(PyFrameObject *frame, PyObject *name, PyObject *qualname)

新建一个包装了 frame 的异步生成器,其中 __name____qualname__ 设为 namequalnameframe 将被此函数取走并且不能为 NULL

成功时,此函数将返回一个指向新异步生成器的 strong reference。 失败时,此函数将返回 NULL 并设置一个异常。

Added in version 3.6.

int PyAsyncGen_CheckExact(PyObject *op)

Return true 如果 op 是一个异步生成器对象则返回真值,否则返回假值。 此函数总是会成功执行。

Added in version 3.6.