代码对象 — Python 文档

来自菜鸟教程
Python/docs/3.10/c-api/code
跳转至:导航、​搜索

代码对象

代码对象是 CPython 实现的低级细节。 每一个都代表一个尚未绑定到函数中的可执行代码块。

type PyCodeObject
用于描述代码对象的对象的 C 结构。 此类型的字段随时可能更改。
PyTypeObject PyCode_Type
这是一个 PyTypeObject 的实例,代表 Python code 类型。
int PyCode_Check(PyObject *co)
如果 cocode 对象,则返回 true。 此功能总是成功。
int PyCode_GetNumFree(PyCodeObject *co)
返回 co 中自由变量的数量。
PyCodeObject *PyCode_New(int argcount, int kwonlyargcount, int nlocals, int stacksize, int flags, PyObject *code, PyObject *consts, PyObject *names, PyObject *varnames, PyObject *freevars, PyObject *cellvars, PyObject *filename, PyObject *name, int firstlineno, PyObject *lnotab)
返回一个新的代码对象。 如果您需要一个虚拟代码对象来创建框架,请改用 PyCode_NewEmpty()。 直接调用 PyCode_New() 可以将您绑定到精确的 Python 版本,因为字节码的定义经常更改。
PyCodeObject *PyCode_NewWithPosOnlyArgs(int argcount, int posonlyargcount, int kwonlyargcount, int nlocals, int stacksize, int flags, PyObject *code, PyObject *consts, PyObject *names, PyObject *varnames, PyObject *freevars, PyObject *cellvars, PyObject *filename, PyObject *name, int firstlineno, PyObject *lnotab)

类似于 PyCode_New(),但有一个额外的“posonlyargcount”用于仅位置参数。

3.8 版中的新功能。

PyCodeObject *PyCode_NewEmpty(const char *filename, const char *funcname, int firstlineno)
返回具有指定文件名、函数名和第一行号的新空代码对象。 exec()eval() 结果代码对象是非法的。
int PyCode_Addr2Line(PyCodeObject *co, int byte_offset)

返回发生在 byte_offset 上或之前并在其之后结束的指令的行号。 如果您只需要帧的行号,请改用 PyFrame_GetLineNumber()

为了有效地迭代代码对象中的行号,请使用 PEP 626 中描述的 API。