В чем разница между асинхронностью, многопоточностью (multithreading) и многопроцессингом (multiproc

Python Middle Без компании
В чем разница между асинхронностью, многопоточностью (multithreading) и многопроцессингом (multiprocessing)
Ответы
Асинхронность — это однопоточный подход, где задачи выполняются конкурентно через event loop, переключаясь при ожидании I/O (например, asyncio). Эффективно для I/O-bound задач. Многопоточность (threading) — параллельное выполнение в одном процессе. Потоки делят память, но из-за GIL в Python не дают реального ускорения для CPU-bound задач. Подходит для I/O-bound, но требует синхронизации. Многопроцессность (multiprocessing) — запуск отдельных процессов с собственной памятью. Обход GIL, идеально для CPU-bound задач. Дороже по ресурсам, сложнее в обмене данными. Пример: ``` # Асинхронность async def fetch(): await asyncio.sleep(1) # Многопоточность def io_task(): time.sleep(1) threading.Thread(target=io_task).start() # Многопроцессность def cpu_task(): [x*x for x in range(10_000)] multiprocessing.Process(target=cpu_task).start() ```