Python 3.13 is now out and the end of the Global Interpreter Lock may be in sight.
The Python Global Interpreter Lock (GIL) is basically a gatekeeper that allows just one thread to control the Python interpreter at a time. That means no matter how many threads or CPU cores you’re running, only one thread is executing Python code at any moment.
If you’re writing single-threaded programs, you won’t even notice the GIL. But if you’re running CPU-heavy, multi-threaded code, you’ll feel the pain—it becomes a bottleneck fast. That’s why the GIL is notorious in the Python world, especially in multi-threaded applications, where it hogs all the action.
Tons of people never run into this, because single-threaded Python programs don’t care, but as you try to scale up, you can hit a wall.
Why Does Python Have a GIL?
Python manages memory with reference counting. Each object has a counter keeping track of how many references point to it. When that number hits zero, Python frees up the memory.
However, if you have multiple threads incrementing and decrementing the counter simultaneously, you quickly descend into chaos. To avoid this, Python could lock every shared object to prevent race conditions. But, more locks mean more chances of deadlocks, which is a mess in itself. So, Python takes a shortcut: a single lock on the interpreter. This keeps things simple—no deadlocks—but at a cost: it makes Python’s multi-threading practically single-threaded when it comes to CPU-bound tasks.
How much this affects your code depends on the code, of course. If you’re I/O-bound, it doesn’t make any differences, but for CPU-bound systems, Python has always lagged true multi-threaded code.
Is the GIL Dead?
Starting with 3.13, a new experimental mode is available:
CPython now has experimental support for running in a free-threaded mode, with the global interpreter lock (GIL) disabled. This is an experimental feature and therefore is not enabled by default.
Free-threaded execution allows for full utilization of the available processing power by running threads in parallel on available CPU cores. While not all software will benefit from this automatically, programs designed with threading in mind will run faster on multi-core hardware. The free-threaded mode is experimental and work is ongoing to improve it: expect some bugs and a substantial single-threaded performance hit. Free-threaded builds of CPython support optionally running with the GIL enabled at runtime using the environment variable
PYTHON_GIL
or the command-line option-X gil=1
.
My guess is that they’ll keep it experimental for a while until practically everyone is using it, then make it standard.
Would this be a Python 4 thing? There is no Python 4 on the horizon but I don’t think this needs a “big release” number. The language isn’t changing, just the engine underneath it, so you don’t have to work about breaking people’s code. If things work out, this could be mainstream before 3.20.
Related Posts:
Enjoy This Index of Thousands of FREE Programming Books! Python, Rust, Javascript, Java, C#, C++, Y...
Just Published: My Powerball Results Checker Script
How to Permanently Dowload Any Book You Can Borrow on archive.org as a PDF
Setup Odoo? Swap out Slack? Create Plugins for Python? Dynamic DNS? We've Got the Tutorials!
Free Udemy Courses! Our Community Resource Just Keeps Going
Implement a Plugin Architecture in Python with Only Two Lines of Code!
- Dropbear in 2025: Still the LowEnd SSH Server of Choice? - January 20, 2025
- “OMG! I Never Knew That!”: The Simply Linux Tip That Has Got Me More Thanks Than Anything I’ve Ever Shared in 30+ Years - January 19, 2025
- Bluesky has Flopped: How Mashable is Lying To You - January 18, 2025
Leave a Reply