Allouer des objets dans le tas¶
-
PyObject*
_PyObject_New
(PyTypeObject *type)¶ - Return value: New reference.
-
PyVarObject*
_PyObject_NewVar
(PyTypeObject *type, Py_ssize_t size)¶ - Return value: New reference.
-
PyObject*
PyObject_Init
(PyObject *op, PyTypeObject *type)¶ - Return value: Borrowed reference.
Permet d'initialiser un objet op nouvellement alloué ainsi que son type et sa référence initiale. Renvoie l'objet initialisé. La présence de type indique que l'objet doit être traité par le détecteur d'ordures cycliques, il est de ce fait ajouté à l'ensemble du détecteur d'objets observés. Les autres champs de l'objet ne sont pas affectés.
-
PyVarObject*
PyObject_InitVar
(PyVarObject *op, PyTypeObject *type, Py_ssize_t size)¶ - Return value: Borrowed reference.
Effectue les mêmes opérations que
PyObject_Init()
fait, et initialise également l'information de la longueur pour un objet de taille variable.
-
TYPE*
PyObject_New
(TYPE, PyTypeObject *type)¶ - Return value: New reference.
Alloue un nouvel objet Python en utilisant le type de structure C TYPE et l'objet Python type. Les champs non définis par l'en-tête de l'objet Python ne sont pas initialisés; le compteur de la référence objet sera égal à un. La taille de l'allocation mémoire est déterminée par le champ
tp_basicsize
de l'objet type.
-
TYPE*
PyObject_NewVar
(TYPE, PyTypeObject *type, Py_ssize_t size)¶ - Return value: New reference.
Alloue un nouvel objet Python en utilisant le type de structure C TYPE et l'objet Python de type type. Les champs non définis par l'en-tête de l'objet Python ne sont pas initialisés. La mémoire allouée est suffisante pour la structure TYPE plus size champs de la taille donnée par le champ de type
tp_itemsize
. Ceci est utile pour l'implémentation d'objets comme les tuples, qui sont capables de déterminer leur taille à la construction. Allouer les champs en même temps que l'objet diminue le nombre d'allocations, améliorant ainsi les performances.
-
void
PyObject_Del
(void *op)¶ Libère la mémoire allouée à un objet utilisant
PyObject_New()
ouPyObject_NewVar()
. Ceci est normalement appelé par le gestionnairetp_dealloc
spécifié dans le type d'objet. Les champs de l'objet ne doivent plus être accédés après cet appel puisque cet emplacement mémoire ne correspond plus à un objet Python valide.
-
PyObject
_Py_NoneStruct
¶ Objet qui est visible en tant que
None
dans Python. Ne devrait être accessible uniquement en utilisant la macroPy_None
, qui évalue cet objet à un pointeur.
Voir aussi
PyModule_Create()
Allouer et créer des modules d'extension.