Thread-first true parallelism
Project description
freethreading — Thread-first true parallelism
freethreading is a lightweight wrapper that provides a unified API for true parallel execution in Python. It
automatically uses threading on free-threaded Python builds (where the
Global Interpreter Lock (GIL) is disabled) and
falls back to multiprocessing on standard ones. This enables true parallelism across Python versions while preferring the efficiency of threads over
processes whenever possible.
Installation
To install freethreading, simply run:
pip install free-threading
To install the latest development version, you can run:
pip install git+https://github.com/iskandergaba/free-threading.git
Quick Start
freethreading is a drop-in replacement for most pre-existing threading and multiprocessing code. To achieve
this, the module exposes only non-deprecated common functionality shared between both backends while discarding any
backend-specific APIs. The following examples show how to get started.
freethreading remains consistent with the standard library, so wrapper classes work as drop-in replacements for those
used by threading and multiprocessing. Here's how they work:
# threading
from queue import Queue
from threading import Event, Lock
# multiprocessing
from multiprocessing import Event, Lock, Queue
# freethreading (replaces both)
from freethreading import Event, Lock, Queue
event = Event()
lock = Lock()
queue = Queue()
lock.acquire()
# True
event.set()
queue.put("data")
event.is_set()
# True
queue.get()
# 'data'
lock.release()
freethreading functions merge as much functionality from both backends as possible to ensure consistent behavior
across backends and simplify adoption. Here's what that looks like:
# threading
from threading import enumerate, get_ident
# multiprocessing
from multiprocessing import active_children
from os import getpid
# freethreading (replaces both)
from freethreading import active_children, enumerate, get_ident
len(active_children()) # excludes current thread or process
# 0
len(enumerate()) # includes current thread or process
# 1
get_ident() # current thread or process identifier
# 140247834...
Only Worker, WorkerPool, WorkerPoolExecutor, and current_worker differ from the standard library naming, using
"worker" as a term for both threads and processes. Below is an example:
Note
On Python 3.14 (standard builds), examples using user-defined functions with
Worker,WorkerPool, orWorkerPoolExecutormust be saved to a.pyfile to run.
# threading
from concurrent.futures import ThreadPoolExecutor
from threading import Thread, current_thread
# multiprocessing
from concurrent.futures import ProcessPoolExecutor
from multiprocessing import Process, current_process
# freethreading (replaces both)
from freethreading import Worker, WorkerPool, WorkerPoolExecutor, current_worker
current_worker().name
# 'MainThread' or 'MainProcess'
def task():
print(f"Hello from {current_worker().name}!")
# Using Worker (Thread or Process) to run a task
w = Worker(target=task, name="MyWorker")
w.start()
w.join()
# Hello from MyWorker!
# Using WorkerPool (Pool or ThreadPool) to distribute work
def square(x):
return x * x
with WorkerPool(workers=2) as pool:
print(pool.map(square, range(5)))
# [0, 1, 4, 9, 16]
# Using WorkerPoolExecutor (ThreadPoolExecutor or ProcessPoolExecutor) to run a task
with WorkerPoolExecutor(max_workers=2) as executor:
future = executor.submit(task)
# 'Hello from ThreadPoolExecutor-0_0!' or 'Hello from ForkProcess-2!'
Documentation
For more details, check out the full documentation at freethreading.readthedocs.io.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file free_threading-1.0.3.tar.gz.
File metadata
- Download URL: free_threading-1.0.3.tar.gz
- Upload date:
- Size: 13.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
38d4c6bd8110f7bc35f9d54a82ff623fb1ddbc6b7d9098115514f2741041203d
|
|
| MD5 |
b757ac299501360eb4a95d5e88c4b560
|
|
| BLAKE2b-256 |
320bfac6cbd3e2b6d27078637b9abc81a34d7f23e21136d860c902eb49df4c80
|
File details
Details for the file free_threading-1.0.3-py3-none-any.whl.
File metadata
- Download URL: free_threading-1.0.3-py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.17 {"installer":{"name":"uv","version":"0.9.17","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
375d51377dd96d53171e51e83d033f223d9aae04d9a35a5d353bd1e5f33bc20e
|
|
| MD5 |
a7f0c43f78f95f691820dd77942df9ba
|
|
| BLAKE2b-256 |
47fb0f5aaa69388cf4c1fafd82388b4d87e3377073573ffdfc5ea325bd2277dc
|