@@ -40,11 +40,18 @@ The :mod:`gc` module provides the following functions:
40
40
41
41
.. function :: collect(generation=2)
42
42
43
- With no arguments, run a full collection. The optional argument *generation *
43
+ Perform a collection. The optional argument *generation *
44
44
may be an integer specifying which generation to collect (from 0 to 2). A
45
- :exc: `ValueError ` is raised if the generation number is invalid. The sum of
45
+ :exc: `ValueError ` is raised if the generation number is invalid. The sum of
46
46
collected objects and uncollectable objects is returned.
47
47
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
+
48
55
The free lists maintained for a number of built-in types are cleared
49
56
whenever a full collection or collection of the highest generation (2)
50
57
is run. Not all items in some free lists may be freed due to the
@@ -53,6 +60,9 @@ The :mod:`gc` module provides the following functions:
53
60
The effect of calling ``gc.collect() `` while the interpreter is already
54
61
performing a collection is undefined.
55
62
63
+ .. versionchanged :: 3.13
64
+ ``generation=1 `` performs an increment of collection.
65
+
56
66
57
67
.. function :: set_debug(flags)
58
68
@@ -68,13 +78,20 @@ The :mod:`gc` module provides the following functions:
68
78
69
79
.. function :: get_objects(generation=None)
70
80
81
+
71
82
Returns a list of all objects tracked by the collector, excluding the list
72
- returned. If *generation * is not ``None ``, return only the objects tracked by
73
- the collector that are in that generation.
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.13)
87
+ * 2: All objects in the old generation
74
88
75
89
.. versionchanged :: 3.8
76
90
New *generation * parameter.
77
91
92
+ .. versionchanged :: 3.13
93
+ Generation 1 is removed
94
+
78
95
.. audit-event :: gc.get_objects generation gc.get_objects
79
96
80
97
.. function :: get_stats()
@@ -101,19 +118,27 @@ The :mod:`gc` module provides the following functions:
101
118
Set the garbage collection thresholds (the collection frequency). Setting
102
119
*threshold0 * to zero disables collection.
103
120
104
- The GC classifies objects into three generations depending on how many
105
- collection sweeps they have survived. New objects are placed in the youngest
106
- generation (generation ``0 ``). If an object survives a collection it is moved
107
- into the next older generation. Since generation ``2 `` is the oldest
108
- generation, objects in that generation remain there after a collection. In
109
- order to decide when to run, the collector keeps track of the number object
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
110
126
allocations and deallocations since the last collection. When the number of
111
127
allocations minus the number of deallocations exceeds *threshold0 *, collection
112
- starts. Initially only generation ``0 `` is examined. If generation ``0 `` has
113
- been examined more than *threshold1 * times since generation ``1 `` has been
114
- examined, then generation ``1 `` is examined as well.
115
- With the third generation, things are a bit more complicated,
116
- see `Collecting the oldest generation <https://devguide.python.org/garbage_collector/#collecting-the-oldest-generation >`_ for more information.
128
+ starts. For each collection, all the objects in the young generation and some
129
+ fraction of the old generation is collected.
130
+
131
+ The fraction of the old generation that is collected is **inversely ** proportional
132
+ to *threshold1 *. The larger *threshold1 * is, the slower objects in the old generation
133
+ are collected.
134
+ For the default value of 10, 1% of the old generation is scanned during each collection.
135
+
136
+ *threshold2 * is ignored.
137
+
138
+ See `Garbage collector design <https://devguide.python.org/garbage_collector >`_ for more information.
139
+
140
+ .. versionchanged :: 3.13
141
+ *threshold2 * is ignored
117
142
118
143
119
144
.. function :: get_count()
0 commit comments