Sobes.tech
Back to questions
Junior — Middle
77

Каким образом можно выполнять многопоточную обработку задач, ограниченных CPU, в Python?

Companies where asked
Effective Mobile

Answer from AI

sobes.tech AI

В Python для многопоточной обработки задач, ограниченных CPU, стандартный модуль threading неэффективен из-за GIL (Global Interpreter Lock), который не позволяет одновременно выполнять байт-код Python в нескольких потоках.

Для эффективного использования нескольких ядер CPU лучше применять модуль multiprocessing, который создает отдельные процессы с собственным интерпретатором Python, обходя ограничение GIL.

Пример использования multiprocessing:

from multiprocessing import Pool

def cpu_bound_task(x):
    # пример вычислительной задачи
    return x * x

if __name__ == '__main__':
    with Pool(processes=4) as pool:
        results = pool.map(cpu_bound_task, range(10))
    print(results)

Такой подход позволяет распараллелить CPU-интенсивные задачи и значительно ускорить их выполнение.