8000 Add section about the design of CPython's garbage collector by pablogsal · Pull Request #562 · python/devguide · GitHub
[go: up one dir, main page]

Skip to content
8000

Add section about the design of CPython's garbage collector #562

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged
merged 28 commits into from
Jan 21, 2020
Merged
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
10ee4fd
Add section about the design of CPython's garbage collector
pablogsal Jan 20, 2020
8aac485
Fix several typos
pablogsal Jan 20, 2020
7776e14
Update garbage_collector.rst
pablogsal Jan 20, 2020
c72ce11
Fix more typos
pablogsal Jan 20, 2020
410487b
Update garbage_collector.rst
pablogsal Jan 20, 2020
b18da79
Update garbage_collector.rst
pablogsal Jan 20, 2020
25d7555
Apply suggestions from code review
pablogsal Jan 20, 2020
811235f
Fix more typos
pablogsal Jan 20, 2020
8b72c71
Update garbage_collector.rst
pablogsal Jan 20, 2020
3b84282
Update garbage_collector.rst
pablogsal Jan 20, 2020
0d3f322
Apply suggestions from code review
pablogsal Jan 21, 2020
d84a267
Apply suggestions from code review
pablogsal Jan 21, 2020
5ca46f7
Fix indentation and rework incomplete sentence
pablogsal Jan 21, 2020
404fcc5
Fix more indentation
pablogsal Jan 21, 2020
8fc0547
Rework sentence about _gc_prev
pablogsal Jan 21, 2020
e956478
Update garbage_collector.rst
pablogsal Jan 21, 2020
47190cd
Fix indentation
pablogsal Jan 21, 2020
722a99c
Fix quotes
pablogsal Jan 21, 2020
b40b030
Fix typo and indentation
pablogsal Jan 21, 2020
111b2bb
Update garbage_collector.rst
pablogsal Jan 21, 2020
2ec5002
Update garbage_collector.rst
pablogsal Jan 21, 2020
7c8e02a
Add author section
pablogsal Jan 21, 2020
e51d354
Add a warning section regarding tagged pointers
pablogsal Jan 21, 2020
411037f
Add reference to the memory layout
pablogsal Jan 21, 2020
4081607
Fix link to the generation section
pablogsal Jan 21, 2020
03178a0
Apply suggestions from code review
pablogsal Jan 21, 2020
6d01e46
Fix more typos
pablogsal Jan 21, 2020
4321593
Address Petr feedback and fix more typos
pablogsal Jan 21, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Update garbage_collector.rst
Co-Authored-By: Tim Peters <tim.peters@gmail.com>
  • Loading branch information
pablogsal and tim-one authored Jan 21, 2020
commit e956478573438f4ab826547dfb35b6a36cf5b836
2 changes: 1 addition & 1 deletion garbage_collector.rst
Original file line number Diff line number Diff line change
Expand Up @@ -409,7 +409,7 @@ The CPython GC makes use of two fat pointers:
* The ``_gc_next`` field is used as the "next" pointer to maintain the doubly
linked list but during collection its lowest bit is used to keep the
``NEXT_MASK_UNREACHABLE`` flag that indicates if an object is tentatively
unreachable during the cycle detection algorithm.
unreachable during the cycle detection algorithm. This is a drawback to using only doubly linked lists to implement partitions: while most needed operations are constant-time, there is no efficient way to determine which partition an object is currently in. Instead, when that's needed, ad hoc tricks (like the ``NEXT_MASK_UNREACHABLE`` flag) are employed.

Optimization: delay tracking containers
---------------------------------------
Expand Down
0