Код C довольно прост, на самом деле.Развернув один макрос и удалив несколько ненужных комментариев, базовая структура находится в listobject.h
, который определяет список следующим образом:
typedef struct {
PyObject_HEAD
Py_ssize_t ob_size;
/* Vector of pointers to list elements. list[0] is ob_item[0], etc. */
PyObject **ob_item;
/* ob_item contains space for 'allocated' elements. The number
* currently in use is ob_size.
* Invariants:
* 0 <= ob_size <= allocated
* len(list) == ob_size
* ob_item == NULL implies ob_size == allocated == 0
*/
Py_ssize_t allocated;
} PyListObject;
PyObject_HEAD
содержит счетчик ссылок и идентификатор типа,Итак, это вектор / массив, который перераспределяется.Код для изменения размера такого массива при заполнении находится в listobject.c
.На самом деле он не удваивает массив, но увеличивается за счет выделения
new_allocated = (newsize >> 3) + (newsize < 9 ? 3 : 6);
new_allocated += newsize;
емкости каждый раз, где newsize
- запрашиваемый размер (необязательно allocated + 1
, поскольку вы можете extend
с помощьюпроизвольное количество элементов вместо append
, по одному их один за другим).
См. также FAQ по Python .