|  | :mod:`gc` --- Garbage Collector interface | 
|  | ========================================= | 
|  |  | 
|  | .. module:: gc | 
|  | :synopsis: Interface to the cycle-detecting garbage collector. | 
|  |  | 
|  | .. moduleauthor:: Neil Schemenauer <nas@arctrix.com> | 
|  | .. sectionauthor:: Neil Schemenauer <nas@arctrix.com> | 
|  |  | 
|  | -------------- | 
|  |  | 
|  | This module provides an interface to the optional garbage collector.  It | 
|  | provides the ability to disable the collector, tune the collection frequency, | 
|  | and set debugging options.  It also provides access to unreachable objects that | 
|  | the collector found but cannot free.  Since the collector supplements the | 
|  | reference counting already used in Python, you can disable the collector if you | 
|  | are sure your program does not create reference cycles.  Automatic collection | 
|  | can be disabled by calling ``gc.disable()``.  To debug a leaking program call | 
|  | ``gc.set_debug(gc.DEBUG_LEAK)``. Notice that this includes | 
|  | ``gc.DEBUG_SAVEALL``, causing garbage-collected objects to be saved in | 
|  | gc.garbage for inspection. | 
|  |  | 
|  | The :mod:`gc` module provides the following functions: | 
|  |  | 
|  |  | 
|  | .. function:: enable() | 
|  |  | 
|  | Enable automatic garbage collection. | 
|  |  | 
|  |  | 
|  | .. function:: disable() | 
|  |  | 
|  | Disable automatic garbage collection. | 
|  |  | 
|  |  | 
|  | .. function:: isenabled() | 
|  |  | 
|  | Returns true if automatic collection is enabled. | 
|  |  | 
|  |  | 
|  | .. function:: collect(generation=2) | 
|  |  | 
|  | With no arguments, run a full collection.  The optional argument *generation* | 
|  | may be an integer specifying which generation to collect (from 0 to 2).  A | 
|  | :exc:`ValueError` is raised if the generation number  is invalid. The number of | 
|  | unreachable objects found is returned. | 
|  |  | 
|  | The free lists maintained for a number of built-in types are cleared | 
|  | whenever a full collection or collection of the highest generation (2) | 
|  | is run.  Not all items in some free lists may be freed due to the | 
|  | particular implementation, in particular :class:`float`. | 
|  |  | 
|  |  | 
|  | .. function:: set_debug(flags) | 
|  |  | 
|  | Set the garbage collection debugging flags. Debugging information will be | 
|  | written to ``sys.stderr``.  See below for a list of debugging flags which can be | 
|  | combined using bit operations to control debugging. | 
|  |  | 
|  |  | 
|  | .. function:: get_debug() | 
|  |  | 
|  | Return the debugging flags currently set. | 
|  |  | 
|  |  | 
|  | .. function:: get_objects() | 
|  |  | 
|  | Returns a list of all objects tracked by the collector, excluding the list | 
|  | returned. | 
|  |  | 
|  |  | 
|  | .. function:: get_stats() | 
|  |  | 
|  | Return a list of three per-generation dictionaries containing collection | 
|  | statistics since interpreter start.  The number of keys may change | 
|  | in the future, but currently each dictionary will contain the following | 
|  | items: | 
|  |  | 
|  | * ``collections`` is the number of times this generation was collected; | 
|  |  | 
|  | * ``collected`` is the total number of objects collected inside this | 
|  | generation; | 
|  |  | 
|  | * ``uncollectable`` is the total number of objects which were found | 
|  | to be uncollectable (and were therefore moved to the :data:`garbage` | 
|  | list) inside this generation. | 
|  |  | 
|  | .. versionadded:: 3.4 | 
|  |  | 
|  |  | 
|  | .. function:: set_threshold(threshold0[, threshold1[, threshold2]]) | 
|  |  | 
|  | Set the garbage collection thresholds (the collection frequency). Setting | 
|  | *threshold0* to zero disables collection. | 
|  |  | 
|  | 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 generation ``2`` 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 generation ``0`` is examined.  If generation ``0`` has | 
|  | been examined more than *threshold1* times since generation ``1`` has been | 
|  | examined, then generation ``1`` is examined as well.  Similarly, *threshold2* | 
|  | controls the number of collections of generation ``1`` before collecting | 
|  | generation ``2``. | 
|  |  | 
|  |  | 
|  | .. function:: get_count() | 
|  |  | 
|  | Return the current collection  counts as a tuple of ``(count0, count1, | 
|  | count2)``. | 
|  |  | 
|  |  | 
|  | .. function:: get_threshold() | 
|  |  | 
|  | Return the current collection thresholds as a tuple of ``(threshold0, | 
|  | threshold1, threshold2)``. | 
|  |  | 
|  |  | 
|  | .. function:: get_referrers(*objs) | 
|  |  | 
|  | Return the list of objects that directly refer to any of objs. This function | 
|  | will only locate those containers which support garbage collection; extension | 
|  | types which do refer to other objects but do not support garbage collection will | 
|  | not be found. | 
|  |  | 
|  | Note that objects which have already been dereferenced, but which live in cycles | 
|  | and have not yet been collected by the garbage collector can be listed among the | 
|  | resulting referrers.  To get only currently live objects, call :func:`collect` | 
|  | before calling :func:`get_referrers`. | 
|  |  | 
|  | Care must be taken when using objects returned by :func:`get_referrers` because | 
|  | some of them could still be under construction and hence in a temporarily | 
|  | invalid state. Avoid using :func:`get_referrers` for any purpose other than | 
|  | debugging. | 
|  |  | 
|  |  | 
|  | .. function:: get_referents(*objs) | 
|  |  | 
|  | Return a list of objects directly referred to by any of the arguments. The | 
|  | referents returned are those objects visited by the arguments' C-level | 
|  | :c:member:`~PyTypeObject.tp_traverse` methods (if any), and may not be all objects actually | 
|  | directly reachable.  :c:member:`~PyTypeObject.tp_traverse` methods are supported only by objects | 
|  | that support garbage collection, and are only required to visit objects that may | 
|  | be involved in a cycle.  So, for example, if an integer is directly reachable | 
|  | from an argument, that integer object may or may not appear in the result list. | 
|  |  | 
|  |  | 
|  | .. function:: is_tracked(obj) | 
|  |  | 
|  | Returns ``True`` if the object is currently tracked by the garbage collector, | 
|  | ``False`` otherwise.  As a general rule, instances of atomic types aren't | 
|  | tracked and instances of non-atomic types (containers, user-defined | 
|  | objects...) are.  However, some type-specific optimizations can be present | 
|  | in order to suppress the garbage collector footprint of simple instances | 
|  | (e.g. dicts containing only atomic keys and values):: | 
|  |  | 
|  | >>> 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 | 
|  |  | 
|  | .. versionadded:: 3.1 | 
|  |  | 
|  |  | 
|  | The following variables are provided for read-only access (you can mutate the | 
|  | values but should not rebind them): | 
|  |  | 
|  | .. data:: garbage | 
|  |  | 
|  | A list of objects which the collector found to be unreachable but could | 
|  | not be freed (uncollectable objects).  Starting with Python 3.4, this | 
|  | list should be empty most of the time, except when using instances of | 
|  | C extension types with a non-NULL ``tp_del`` slot. | 
|  |  | 
|  | If :const:`DEBUG_SAVEALL` is set, then all unreachable objects will be | 
|  | added to this list rather than freed. | 
|  |  | 
|  | .. versionchanged:: 3.2 | 
|  | If this list is non-empty at :term:`interpreter shutdown`, a | 
|  | :exc:`ResourceWarning` is emitted, which is silent by default.  If | 
|  | :const:`DEBUG_UNCOLLECTABLE` is set, in addition all uncollectable objects | 
|  | are printed. | 
|  |  | 
|  | .. versionchanged:: 3.4 | 
|  | Following :pep:`442`, objects with a :meth:`__del__` method don't end | 
|  | up in :attr:`gc.garbage` anymore. | 
|  |  | 
|  | .. data:: callbacks | 
|  |  | 
|  | A list of callbacks that will be invoked by the garbage collector before and | 
|  | after collection.  The callbacks will be called with two arguments, | 
|  | *phase* and *info*. | 
|  |  | 
|  | *phase* can be one of two values: | 
|  |  | 
|  | "start": The garbage collection is about to start. | 
|  |  | 
|  | "stop": The garbage collection has finished. | 
|  |  | 
|  | *info* is a dict providing more information for the callback.  The following | 
|  | keys are currently defined: | 
|  |  | 
|  | "generation": The oldest generation being collected. | 
|  |  | 
|  | "collected": When *phase* is "stop", the number of objects | 
|  | successfully collected. | 
|  |  | 
|  | "uncollectable": When *phase* is "stop", the number of objects | 
|  | that could not be collected and were put in :data:`garbage`. | 
|  |  | 
|  | Applications can add their own callbacks to this list.  The primary | 
|  | use cases are: | 
|  |  | 
|  | Gathering statistics about garbage collection, such as how often | 
|  | various generations are collected, and how long the collection | 
|  | takes. | 
|  |  | 
|  | Allowing applications to identify and clear their own uncollectable | 
|  | types when they appear in :data:`garbage`. | 
|  |  | 
|  | .. versionadded:: 3.3 | 
|  |  | 
|  |  | 
|  | The following constants are provided for use with :func:`set_debug`: | 
|  |  | 
|  |  | 
|  | .. data:: DEBUG_STATS | 
|  |  | 
|  | Print statistics during collection.  This information can be useful when tuning | 
|  | the collection frequency. | 
|  |  | 
|  |  | 
|  | .. data:: DEBUG_COLLECTABLE | 
|  |  | 
|  | Print information on collectable objects found. | 
|  |  | 
|  |  | 
|  | .. data:: DEBUG_UNCOLLECTABLE | 
|  |  | 
|  | Print information of uncollectable objects found (objects which are not | 
|  | reachable but cannot be freed by the collector).  These objects will be added | 
|  | to the ``garbage`` list. | 
|  |  | 
|  | .. versionchanged:: 3.2 | 
|  | Also print the contents of the :data:`garbage` list at | 
|  | :term:`interpreter shutdown`, if it isn't empty. | 
|  |  | 
|  | .. data:: DEBUG_SAVEALL | 
|  |  | 
|  | When set, all unreachable objects found will be appended to *garbage* rather | 
|  | than being freed.  This can be useful for debugging a leaking program. | 
|  |  | 
|  |  | 
|  | .. data:: DEBUG_LEAK | 
|  |  | 
|  | The debugging flags necessary for the collector to print information about a | 
|  | leaking program (equal to ``DEBUG_COLLECTABLE | DEBUG_UNCOLLECTABLE | | 
|  | DEBUG_SAVEALL``). |