@@ -40,18 +40,11 @@ The :mod:`!gc` module provides the following functions:
4040
4141.. function :: collect(generation=2)
4242
43- Perform a collection. The optional argument *generation *
43+ With no arguments, run a full collection. The optional argument *generation *
4444 may be an integer specifying which generation to collect (from 0 to 2). A
4545 :exc: `ValueError ` is raised if the generation number is invalid. The sum of
4646 collected objects and uncollectable objects is returned.
4747
48- Calling ``gc.collect(0) `` will perform a GC collection on the young generation.
49-
50- Calling ``gc.collect(1) `` will perform a GC collection on the young generation
51- and an increment of the old generation.
52-
53- Calling ``gc.collect(2) `` or ``gc.collect() `` performs a full collection
54-
5548 The free lists maintained for a number of built-in types are cleared
5649 whenever a full collection or collection of the highest generation (2)
5750 is run. Not all items in some free lists may be freed due to the
@@ -60,9 +53,6 @@ The :mod:`!gc` module provides the following functions:
6053 The effect of calling ``gc.collect() `` while the interpreter is already
6154 performing a collection is undefined.
6255
63- .. versionchanged :: 3.14
64- ``generation=1 `` performs an increment of collection.
65-
6656
6757.. function :: set_debug(flags)
6858
@@ -80,18 +70,12 @@ The :mod:`!gc` module provides the following functions:
8070
8171
8272 Returns a list of all objects tracked by the collector, excluding the list
83- returned. If *generation * is not ``None ``, return only the objects as follows:
84-
85- * 0: All objects in the young generation
86- * 1: No objects, as there is no generation 1 (as of Python 3.14)
87- * 2: All objects in the old generation
73+ returned. If *generation * is not ``None ``, return only the objects tracked by
74+ the collector that are in that generation.
8875
8976 .. versionchanged :: 3.8
9077 New *generation * parameter.
9178
92- .. versionchanged :: 3.14
93- Generation 1 is removed
94-
9579 .. audit-event :: gc.get_objects generation gc.get_objects
9680
9781.. function :: get_stats()
@@ -108,43 +92,49 @@ The :mod:`!gc` module provides the following functions:
10892
10993 * ``uncollectable `` is the total number of objects which were found
11094 to be uncollectable (and were therefore moved to the :data: `garbage `
111- list) inside this generation.
95+ list) inside this generation;
96+
97+ * ``candidates `` is the total number of objects in this generation which were
98+ considered for collection and traversed;
99+
100+ * ``duration `` is the total time in seconds spent in collections for this
101+ generation.
112102
113103 .. versionadded :: 3.4
114104
105+ .. versionchanged :: 3.14
106+ Add ``duration `` and ``candidates ``.
107+
115108
116109.. function :: set_threshold(threshold0, [threshold1, [threshold2]])
117110
118111 Set the garbage collection thresholds (the collection frequency). Setting
119112 *threshold0 * to zero disables collection.
120113
121- The GC classifies objects into two generations depending on whether they have
122- survived a collection. New objects are placed in the young generation. If an
123- object survives a collection it is moved into the old generation.
124-
125- In order to decide when to run, the collector keeps track of the number of object
114+ The GC classifies objects into three generations depending on how many
115+ collection sweeps they have survived. New objects are placed in the youngest
116+ generation (generation ``0 ``). If an object survives a collection it is moved
117+ into the next older generation. Since generation ``2 `` is the oldest
118+ generation, objects in that generation remain there after a collection. In
119+ order to decide when to run, the collector keeps track of the number object
126120 allocations and deallocations since the last collection. When the number of
127121 allocations minus the number of deallocations exceeds *threshold0 *, collection
128- starts. For each collection, all the objects in the young generation and some
129- fraction of the old generation is collected.
122+ starts. Initially only generation ``0 `` is examined. If generation ``0 `` has
123+ been examined more than *threshold1 * times since generation ``1 `` has been
124+ examined, then generation ``1 `` is examined as well.
125+ With the third generation, things are a bit more complicated,
126+ see `Garbage collector design <https://github.com/python/cpython/blob/3.14/InternalDocs/garbage_collector.md >`_
127+ for more information.
128+
129+ .. note ::
130+ In the free-threaded build, the cycle collector is not generational.
131+ Collections operate over the entire tracked heap.
130132
131133 In the free-threaded build, the increase in process memory usage is also
132- checked before running the collector. If the memory usage has not increased
134+ checked before running the collector. If the memory usage has not increased
133135 by 10% since the last collection and the net number of object allocations
134136 has not exceeded 40 times *threshold0 *, the collection is not run.
135137
136- The fraction of the old generation that is collected is **inversely ** proportional
137- to *threshold1 *. The larger *threshold1 * is, the slower objects in the old generation
138- are collected.
139- For the default value of 10, 1% of the old generation is scanned during each collection.
140-
141- *threshold2 * is ignored.
142-
143- See `Garbage collector design <https://github.com/python/cpython/blob/3.14/InternalDocs/garbage_collector.md >`_ for more information.
144-
145- .. versionchanged :: 3.14
146- *threshold2 * is ignored
147-
148138
149139.. function :: get_count()
150140
0 commit comments