В чем разница между асинхронностью, многопоточностью (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()
```