类型注解对象

提供几种用于类型提示的内置类型。 目前存在两种类型 -- GenericAliasUnion。 只有 GenericAlias 会向 C 开放。

PyObject *Py_GenericAlias(PyObject *origin, PyObject *args)
Part of the Stable ABI since version 3.9.

创建一个 GenericAlias 对象。 相当于调用 Python 类 types.GenericAlias。 参数 originargs 分别设置 GenericAlias__origin____args__ 属性。 origin 应该是一个 PyTypeObject*,而 args 可以是一个 PyTupleObject* 或者任意 PyObject*。 如果传递的 args 不是一个元组,则会自动构造一个单元组并将 __args__ 设置为 (args,)。 对参数进行了最小限度的检查,因此即使 origin 不是类型函数也会成功。 GenericAlias__parameters__ 属性是从 __args__ 懒加载的。 如果失败,则会引发一个异常并返回 NULL

下面是一个如何创建一个扩展类型泛型的例子:

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

也參考

数据模型的方法 __class_getitem__()

3.9 版新加入.

PyTypeObject Py_GenericAliasType
Part of the Stable ABI since version 3.9.

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

3.9 版新加入.