형 객체¶
-
type PyTypeObject¶
- Part of the Limited API (as an opaque struct).
내장형을 기술하는 데 사용되는 객체의 C 구조체.
-
PyTypeObject PyType_Type¶
- Part of the Stable ABI.
이것은 형 객체의 형 객체입니다; 파이썬 계층의
type
과 같은 객체입니다.
-
int PyType_Check(PyObject *o)¶
객체 o가 표준형 객체에서 파생된 형의 인스턴스를 포함하여 형 객체면 0이 아닌 값을 반환합니다. 다른 모든 경우 0을 반환합니다. 이 함수는 항상 성공합니다.
-
int PyType_CheckExact(PyObject *o)¶
객체 o가 형 객체이지만, 표준형 객체의 서브 형이 아니면 0이 아닌 값을 반환합니다. 다른 모든 경우 0을 반환합니다. 이 함수는 항상 성공합니다.
-
unsigned int PyType_ClearCache()¶
- Part of the Stable ABI.
내부 조회 캐시를 지웁니다. 현재의 버전 태그를 반환합니다.
-
unsigned long PyType_GetFlags(PyTypeObject *type)¶
- Part of the Stable ABI.
Return the
tp_flags
member of type. This function is primarily meant for use withPy_LIMITED_API
; the individual flag bits are guaranteed to be stable across Python releases, but access totp_flags
itself is not part of the limited API.버전 3.2에 추가.
버전 3.4에서 변경: 반환형은 이제
long
이 아니라unsigned long
입니다.
-
void PyType_Modified(PyTypeObject *type)¶
- Part of the Stable ABI.
형과 그것의 모든 서브 형에 대한 내부 검색 캐시를 무효로 합니다. 형의 어트리뷰트나 베이스 클래스를 수동으로 수정한 후에는 이 함수를 호출해야 합니다.
-
int PyType_HasFeature(PyTypeObject *o, int feature)¶
형 객체 o가 기능 feature를 설정하면 0이 아닌 값을 반환합니다. 형 기능은 단일 비트 플래그로 표시됩니다.
-
int PyType_IS_GC(PyTypeObject *o)¶
Return true if the type object includes support for the cycle detector; this tests the type flag
Py_TPFLAGS_HAVE_GC
.
-
int PyType_IsSubtype(PyTypeObject *a, PyTypeObject *b)¶
- Part of the Stable ABI.
a가 b의 서브 형이면 참을 반환합니다.
이 함수는 실제 서브 형만 검사합니다. 즉,
__subclasscheck__()
가 b에 대해 호출되지 않습니다.issubclass()
가 수행하는 것과 같은 검사를 하려면PyObject_IsSubclass()
를 호출하십시오.
-
PyObject *PyType_GenericAlloc(PyTypeObject *type, Py_ssize_t nitems)¶
- Return value: New reference. Part of the Stable ABI.
형 객체의
tp_alloc
슬롯을 위한 일반 처리기. 파이썬의 기본 메모리 할당 메커니즘을 사용하여 새 인스턴스를 할당하고 모든 내용을NULL
로 초기화합니다.
-
PyObject *PyType_GenericNew(PyTypeObject *type, PyObject *args, PyObject *kwds)¶
- Return value: New reference. Part of the Stable ABI.
형 객체의
tp_new
슬롯을 위한 일반 처리기. 형의tp_alloc
슬롯을 사용하여 새 인스턴스를 만듭니다.
-
int PyType_Ready(PyTypeObject *type)¶
- Part of the Stable ABI.
형 개체를 마무리합니다. 초기화를 완료하려면 모든 형 객체에 대해 이 메서드를 호출해야 합니다. 이 함수는 형의 베이스 클래스에서 상속된 슬롯을 추가합니다. 성공 시
0
을 반환하고, 오류 시-1
을 반환하고 예외를 설정합니다.참고
If some of the base classes implements the GC protocol and the provided type does not include the
Py_TPFLAGS_HAVE_GC
in its flags, then the GC protocol will be automatically implemented from its parents. On the contrary, if the type being created does includePy_TPFLAGS_HAVE_GC
in its flags then it must implement the GC protocol itself by at least implementing thetp_traverse
handle.
-
PyObject *PyType_GetName(PyTypeObject *type)¶
- Return value: New reference. Part of the Stable ABI since version 3.11.
Return the type’s name. Equivalent to getting the type’s
__name__
attribute.버전 3.11에 추가.
-
PyObject *PyType_GetQualName(PyTypeObject *type)¶
- Return value: New reference. Part of the Stable ABI since version 3.11.
Return the type’s qualified name. Equivalent to getting the type’s
__qualname__
attribute.버전 3.11에 추가.
-
void *PyType_GetSlot(PyTypeObject *type, int slot)¶
- Part of the Stable ABI since version 3.4.
지정된 슬롯에 저장된 함수 포인터를 반환합니다. 결과가
NULL
이면, 슬롯이NULL
이거나 함수가 유효하지 않은 매개 변수로 호출되었음을 나타냅니다. 호출자는 일반적으로 결과 포인터를 적절한 함수 형으로 캐스팅합니다.slot 인자의 가능한 값은
PyType_Slot.slot
을 참조하십시오.버전 3.4에 추가.
버전 3.10에서 변경:
PyType_GetSlot()
can now accept all types. Previously, it was limited to heap types.
-
PyObject *PyType_GetModule(PyTypeObject *type)¶
- Part of the Stable ABI since version 3.10.
PyType_FromModuleAndSpec()
를 사용하여 형을 만들 때 지정된 형과 관련된 모듈 객체를 반환합니다.주어진 형과 연관된 모듈이 없으면,
TypeError
를 설정하고NULL
을 반환합니다.This function is usually used to get the module in which a method is defined. Note that in such a method,
PyType_GetModule(Py_TYPE(self))
may not return the intended result.Py_TYPE(self)
may be a subclass of the intended class, and subclasses are not necessarily defined in the same module as their superclass. SeePyCMethod
to get the class that defines the method. SeePyType_GetModuleByDef()
for cases whenPyCMethod
cannot be used.버전 3.9에 추가.
-
void *PyType_GetModuleState(PyTypeObject *type)¶
- Part of the Stable ABI since version 3.10.
주어진 형과 관련된 모듈 객체의 상태를 반환합니다.
PyType_GetModule()
결과에PyModule_GetState()
를 호출하는 바로 가기입니다.주어진 형과 연관된 모듈이 없으면,
TypeError
를 설정하고NULL
을 반환합니다.type에 연관된 모듈이 있지만, 상태가
NULL
이면, 예외를 설정하지 않고NULL
을 반환합니다.버전 3.9에 추가.
-
PyObject *PyType_GetModuleByDef(PyTypeObject *type, struct PyModuleDef *def)¶
Find the first superclass whose module was created from the given
PyModuleDef
def, and return that module.If no module is found, raises a
TypeError
and returnsNULL
.This function is intended to be used together with
PyModule_GetState()
to get module state from slot methods (such astp_init
ornb_add
) and other places where a method’s defining class cannot be passed using thePyCMethod
calling convention.버전 3.11에 추가.
힙에 할당된 형 만들기¶
다음 함수와 구조체는 힙 형을 만드는 데 사용됩니다.
-
PyObject *PyType_FromModuleAndSpec(PyObject *module, PyType_Spec *spec, PyObject *bases)¶
- Return value: New reference. Part of the Stable ABI since version 3.10.
Creates and returns a heap type from the spec (
Py_TPFLAGS_HEAPTYPE
).The bases argument can be used to specify base classes; it can either be only one class or a tuple of classes. If bases is
NULL
, the Py_tp_bases slot is used instead. If that also isNULL
, the Py_tp_base slot is used instead. If that also isNULL
, the new type derives fromobject
.The module argument can be used to record the module in which the new class is defined. It must be a module object or
NULL
. If notNULL
, the module is associated with the new type and can later be retrieved withPyType_GetModule()
. The associated module is not inherited by subclasses; it must be specified for each class individually.이 함수는 새로운 형에
PyType_Ready()
를 호출합니다.버전 3.9에 추가.
버전 3.10에서 변경: The function now accepts a single class as the bases argument and
NULL
as thetp_doc
slot.
-
PyObject *PyType_FromSpecWithBases(PyType_Spec *spec, PyObject *bases)¶
- Return value: New reference. Part of the Stable ABI since version 3.3.
PyType_FromModuleAndSpec(NULL, spec, bases)
와 동등합니다.버전 3.3에 추가.
-
PyObject *PyType_FromSpec(PyType_Spec *spec)¶
- Return value: New reference. Part of the Stable ABI.
PyType_FromSpecWithBases(spec, NULL)
와 동등합니다.
-
type PyType_Spec¶
- Part of the Stable ABI (including all members).
형의 행동을 정의하는 구조체.
-
const char *PyType_Spec.name¶
형의 이름,
PyTypeObject.tp_name
을 설정하는 데 사용됩니다.
-
int PyType_Spec.basicsize¶
-
int PyType_Spec.itemsize¶
인스턴스의 크기(바이트),
PyTypeObject.tp_basicsize
와PyTypeObject.tp_itemsize
를 설정하는 데 사용됩니다.
-
int PyType_Spec.flags¶
형 플래그,
PyTypeObject.tp_flags
를 설정하는 데 사용됩니다.Py_TPFLAGS_HEAPTYPE
플래그가 설정되어 있지 않으면,PyType_FromSpecWithBases()
가 자동으로 플래그를 설정합니다.
-
PyType_Slot *PyType_Spec.slots¶
PyType_Slot
구조체의 배열. 특수 슬롯값{0, NULL}
에 의해 종료됩니다.
-
const char *PyType_Spec.name¶
-
type PyType_Slot¶
- Part of the Stable ABI (including all members).
형의 선택적 기능을 정의하는 구조체, 슬롯 ID와 값 포인터를 포함합니다.
-
int PyType_Slot.slot¶
슬롯 ID.
슬롯 ID는 구조체
PyTypeObject
,PyNumberMethods
,PySequenceMethods
,PyMappingMethods
및PyAsyncMethods
의 필드 이름에Py_
접두사를 붙인 이름을 사용합니다. 예를 들어, :PyTypeObject.tp_dealloc
을 설정하는Py_tp_dealloc
PyNumberMethods.nb_add
를 설정하는Py_nb_add
PySequenceMethods.sq_length
를 설정하는Py_sq_length
다음 필드는
PyType_Spec
과PyType_Slot
을 사용하여 전혀 설정할 수 없습니다:tp_weaklistoffset
(PyMemberDef를 참조하십시오)tp_dictoffset
(PyMemberDef를 참조하십시오)tp_vectorcall_offset
(PyMemberDef를 참조하십시오)
Setting
Py_tp_bases
orPy_tp_base
may be problematic on some platforms. To avoid issues, use the bases argument ofPyType_FromSpecWithBases()
instead.버전 3.9에서 변경: Slots in
PyBufferProcs
may be set in the unlimited API.버전 3.11에서 변경:
bf_getbuffer
andbf_releasebuffer
are now available under the limited API.
-
void *PyType_Slot.pfunc¶
슬롯의 원하는 값입니다. 대부분 이것은 함수에 대한 포인터입니다.
Slots other than
Py_tp_doc
may not beNULL
.
-
int PyType_Slot.slot¶