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()" ou
   "PyObject_NewVar()". Ceci est normalement appelé par le
   gestionnaire "tp_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 macro "Py_None", qui
   évalue cet objet à un pointeur.

Voir aussi:

  "PyModule_Create()"
     Allouer et créer des modules d'extension.
