类型提示对象

提供了各种用于类型提示的内置类型。目前,存在两种类型 - GenericAliasUnion。只有 GenericAlias 对 C 可见。

PyObject *Py_GenericAlias(PyObject *origin, PyObject *args)
自 3.9 版本起,属于 稳定 ABI 的一部分。

创建一个 GenericAlias 对象。等效于调用 Python 类 types.GenericAliasoriginargs 参数分别设置 GenericAlias__origin____args__ 属性。origin 应该是一个 PyTypeObject*,而 args 可以是 PyTupleObject* 或任何 PyObject*。如果传递的 args 不是元组,则会自动构造一个 1 元组,并将 __args__ 设置为 (args,)。对参数进行的检查很少,因此即使 origin 不是类型,该函数也会成功。GenericAlias__parameters__ 属性是从 __args__ 延迟构造的。如果失败,则会引发异常并返回 NULL

以下是如何使扩展类型泛化的示例

...
static PyMethodDef my_obj_methods[] = {
    // Other methods.
    ...
    {"__class_getitem__", Py_GenericAlias, METH_O|METH_CLASS, "See PEP 585"}
    ...
}

另请参阅

数据模型方法 __class_getitem__().

在 3.9 版本中添加。

PyTypeObject Py_GenericAliasType
自 3.9 版本起,属于 稳定 ABI 的一部分。

Py_GenericAlias() 返回的对象的 C 类型。等效于 Python 中的 types.GenericAlias

在 3.9 版本中添加。