gc
— Interfaz del recolector de basura¶
Este módulo proporciona una interfaz para el recolector de basura opcional (recolector de basura cíclico generacional). Proporciona la capacidad de deshabilitar el recolector, ajustar la frecuencia de recolección y establecer opciones de depuración. También proporciona acceso a objetos inaccesibles (unreachables) que el recolector encontró pero no pudo liberar. Dado que el recolector de basura complementa el conteo de referencias, que ya se utiliza en Python, es posible desactivarlo siempre que se esté seguro de que el programa no crea referencias cíclicas. La recolección automática se puede desactivar llamando a gc.disable()
. Para depurar un programa con fugas de memoria, se debe llamar a gc.set_debug(gc.DEBUG_LEAK)
. Se debe tener en cuenta que la llamada anterior incluye gc.DEBUG_SAVEALL
, lo que hace que los objetos recolectados se guarden en gc.garbage para su inspección.
El módulo gc
proporciona las siguientes funciones:
-
gc.
enable
()¶ Habilita la recolección automática de basura.
-
gc.
disable
()¶ Deshabilita la recolección automática de basura.
-
gc.
isenabled
()¶ Retorna
True
si la recolección automática está habilitada.
-
gc.
collect
(generation=2)¶ Sin argumentos, ejecuta una recolección completa. El argumento opcional generation debe ser un número entero que especifica qué generación recolectar (de 0 a 2). Una excepción
ValueError
será lanzada si el número de generación no es válido. Se retorna el número de objetos inaccesibles encontrados.Las listas libres mantenidas para varios tipos incorporados son borradas cada vez que se ejecuta una recolección completa o una recolección de la generación más alta (2). No obstante, no todos los elementos de algunas listas libres pueden ser liberados, particularmente
float
, debido a su implementación particular.
-
gc.
set_debug
(flags)¶ Establece las flags de depuración para la recolección de basura. La información de depuración se escribirá en
sys.stderr
. A continuación se puede consultar una lista con las flags de depuración disponibles, que se pueden combinar mediante operaciones de bits para controlar la depuración.
-
gc.
get_debug
()¶ Retorna las flags de depuración actualmente establecidas.
-
gc.
get_objects
(generation=None)¶ Retorna una lista de todos los objetos rastreados por el recolector, excluyendo la lista retornada. Si generation no es
None
, retorna solo los objetos rastreados por el recolector que pertenecen a esa generación.Distinto en la versión 3.8: Se agregó el parámetro generation.
Raises an auditing event
gc.get_objects
with argumentgeneration
.
-
gc.
get_stats
()¶ Retorna una lista de tres diccionarios, uno por cada generación, que contienen estadísticas de recolección desde el inicio del intérprete. El número de claves puede cambiar en el futuro, pero actualmente cada diccionario contendrá los siguientes elementos:
collections
es el número de veces que se recolectó esta generación;collected
es el número total de objetos recolectados dentro de esta generación;uncollectable
es el número total de objetos que se consideraron no recolectables (y por lo tanto, se movieron a la listagarbage
) dentro de esta generación.
Nuevo en la versión 3.4.
-
gc.
set_threshold
(threshold0[, threshold1[, threshold2]])¶ Establece los umbrales de recolección (la frecuencia de recolección). Si se establece threshold0 en cero se deshabilita la recolección.
The GC classifies objects into three generations depending on how many collection sweeps they have survived. New objects are placed in the youngest generation (generation
0
). If an object survives a collection it is moved into the next older generation. Since generation2
is the oldest generation, objects in that generation remain there after a collection. In order to decide when to run, the collector keeps track of the number object allocations and deallocations since the last collection. When the number of allocations minus the number of deallocations exceeds threshold0, collection starts. Initially only generation0
is examined. If generation0
has been examined more than threshold1 times since generation1
has been examined, then generation1
is examined as well. With the third generation, things are a bit more complicated, see Collecting the oldest generation for more information.
-
gc.
get_count
()¶ Retorna los recuentos de la recolección actual como una tupla de la forma
(count0, count1, count2)
.
-
gc.
get_threshold
()¶ Retorna los umbrales de la recolección actual como una tupla de la forma
(threshold0, threshold1, threshold2)
.
-
gc.
get_referrers
(*objs)¶ Retorna la lista de objetos que referencian de forma directa a cualquiera de objs. Esta función solo localizará aquellos contenedores que admitan la recolección de basura; no se localizarán los tipos de extensión que referencian a otros objetos pero que no admiten la recolección de basura.
Téngase en cuenta que los objetos que ya se han desreferenciado, pero que tienen referencias cíclicas y aún no han sido recolectados por el recolector de basura pueden enumerarse entre las referencias resultantes. Para obtener solo los objetos activos actualmente, llame a
collect()
antes de llamar aget_referrers()
.Advertencia
Se debe tener un especial cuidado cuando se usan objetos retornados por
get_referrers()
dado que algunos de ellos aún podrían estar en construcción y por tanto en un estado temporalmente inválido. Debe evitarse el uso deget_referrers()
para cualquier propósito que no sea la depuración.Raises an auditing event
gc.get_referrers
with argumentobjs
.
-
gc.
get_referents
(*objs)¶ Retorna una lista de objetos a los que hace referencia directamente cualquiera de los argumentos. Las referencias retornadas son aquellos objetos visitados por los métodos
tp_traverse
a nivel de C de los argumentos (si los hay) y es posible que no todos los objetos sean directamente accesibles realmente. Los métodostp_traverse
solo son compatibles con los objetos que admiten recolección de basura y solo se requieren para visitar objetos que pueden estar involucrados en un ciclo de referencias. Lo que quiere decir que, por ejemplo, si se puede acceder directamente a un número entero desde uno de los argumento, ese objeto entero puede aparecer o no en la lista de resultados.Raises an auditing event
gc.get_referents
with argumentobjs
.
-
gc.
is_tracked
(obj)¶ Retorna
True
si el recolector de basura rastrea actualmente el objeto yFalse
en caso contrario. Como regla general, las instancias de tipos atómicos no se rastrean y las instancias de tipos no atómicos (contenedores, objetos definidos por el usuario …) sí. Sin embargo, algunas optimizaciones específicas de tipo pueden estar presentes para suprimir el impacto del recolector de basura en instancias simples (por ejemplo, diccionarios que contienen solo claves y valores atómicos):>>> gc.is_tracked(0) False >>> gc.is_tracked("a") False >>> gc.is_tracked([]) True >>> gc.is_tracked({}) False >>> gc.is_tracked({"a": 1}) False >>> gc.is_tracked({"a": []}) True
Nuevo en la versión 3.1.
-
gc.
freeze
()¶ Congela todos los objetos rastreados por el recolector de basura - los mueve a una generación permanente e ignora todas las recolecciones futuras. Esto se puede usar antes de una llamada a fork() de POSIX para hacer el recolector de basura amigable con copy-on-write («copiar al escribir») o para acelerar la recolección. Además, la recolección antes de una llamada fork() de POSIX puede liberar páginas para futuras asignaciones, lo que también puede causar copy-on-write, por lo que se recomienda deshabilitar el recolector de basura en el proceso principal, congelar antes de la bifurcación y habilitarlo posteriormente en el proceso secundario.
Nuevo en la versión 3.7.
-
gc.
unfreeze
()¶ Descongela los objetos de la generación permanente y vuelve a colocarlos en la generación más antigua.
Nuevo en la versión 3.7.
-
gc.
get_freeze_count
()¶ Retorna el número de objetos de la generación permanente.
Nuevo en la versión 3.7.
Las siguientes variables se proporcionan para acceso de solo lectura (se pueden mutar los valores pero no se deben vincular de nuevo):
-
gc.
garbage
¶ Una lista de objetos que el recolector consideró inaccesibles pero que no pudieron ser liberados (objetos que no se pueden recolectar). A partir de Python 3.4, esta lista debe estar vacía la mayor parte del tiempo, excepto cuando se utilizan instancias de tipos de extensión C en los que la ranura (slot)
tp_del
no seaNULL
.Si se establece
DEBUG_SAVEALL
, todos los objetos inaccesibles se agregarán a esta lista en lugar de ser liberados.Distinto en la versión 3.2: Si la lista no está vacía en el momento del interpreter shutdown, se emite un
ResourceWarning
, que es silencioso de forma predeterminada. Si se estableceDEBUG_UNCOLLECTABLE
, además se imprimen todos los objetos no recolectables.Distinto en la versión 3.4: Cumpliendo con PEP 442, los objetos con un método
__del__()
ya no terminan engc.garbage
.
-
gc.
callbacks
¶ Una lista de retrollamadas que el recolector de basura invocará antes y después de la recolección. Las retrollamadas serán llamadas con dos argumentos, phase e info.
phase puede tomar uno de estos valores:
«start»: la recolección de basura está a punto de comenzar.
«stop»: la recolección de basura ha terminado.
info es un diccionario que proporciona información adicional para la retrollamada. Las siguientes claves están definidas actualmente:
«generation»: la generación más antigua que ha sido recolectada.
«collected»: cuando phase es «stop», el número de objetos recolectados satisfactoriamente.
«uncollectable»: cuando phase es «stop», el número de objetos que no pudieron ser recolectados y fueron ubicados en
garbage
.Las aplicaciones pueden agregar sus propias retrollamadas a esta lista. Los principales casos de uso son:
Recopilar estadísticas sobre la recolección de basura, como la frecuencia con la que se recolectan varias generaciones y cuánto tiempo lleva la recolección.
Permitir que las aplicaciones identifiquen y borren sus propios tipos no recolectables cuando aparecen en
garbage
.Nuevo en la versión 3.3.
Las siguientes constantes son proporcionadas para ser usadas con set_debug()
:
-
gc.
DEBUG_STATS
¶ Imprime estadísticas durante la recolección. Esta información puede resultar útil para ajustar la frecuencia de recolección.
-
gc.
DEBUG_COLLECTABLE
¶ Imprime información sobre los objetos recolectables encontrados.
-
gc.
DEBUG_UNCOLLECTABLE
¶ Imprime información sobre los objetos no recolectables encontrados (objetos inaccesibles, pero que el recolector no puede liberar). Estos objetos se agregarán a la lista
garbage
.Distinto en la versión 3.2: También imprime el contenido de la lista
garbage
durante interpreter shutdown, si no está vacía.
-
gc.
DEBUG_SAVEALL
¶ Cuando se establece, todos los objetos inaccesibles encontrados se agregarán a garbage en lugar de ser liberados. Esto puede resultar útil para depurar un programa con fugas de memoria.
-
gc.
DEBUG_LEAK
¶ Las flags de depuración necesarias para que el recolector imprima información sobre un programa con fugas de memoria (igual a
DEBUG_COLLECTABLE | DEBUG_UNCOLLECTABLE | DEBUG_SAVEALL
).