Rumah > pembangunan bahagian belakang > Tutorial Python > Bilakah Saya Harus Menggunakan ThreadPool Python Daripada Multiprocessing.Pool?

Bilakah Saya Harus Menggunakan ThreadPool Python Daripada Multiprocessing.Pool?

Barbara Streisand
Lepaskan: 2024-12-26 09:35:09
asal
442 orang telah melayarinya

When Should I Use Python's ThreadPool Instead of multiprocessing.Pool?

Threading Pools dalam Python: Alternatif kepada Pool multiprocessing

Kelas Pool modul multiprocessing menyediakan cara yang mudah untuk menyelaraskan kod menggunakan proses pekerja . Walau bagaimanapun, untuk kes penggunaan tertentu, mungkin lebih baik untuk memanfaatkan benang dan bukannya proses. Artikel ini meneroka antara muka Pool berasaskan benang alternatif yang tersedia dalam modul berbilang pemprosesan.

Pernyataan Masalah:

Seorang pengguna mencari perpustakaan Python yang menawarkan kelas "Pool" untuk proses pekerja threading, serupa dengan kelas Pool modul multiprocessing. Ini akan membolehkan penyelarasan tugas yang serupa dengan contoh berikut menggunakan Kolam pemproses berbilang:

def long_running_func(p):
    c_func_no_gil(p)

p = multiprocessing.Pool(4)
xs = p.map(long_running_func, range(100))
Salin selepas log masuk

Walau bagaimanapun, pengguna ingin mengelakkan overhed yang berkaitan dengan mencipta proses baharu.

Penyelesaian:

Modul berbilang pemprosesan termasuk antara muka Pool berasaskan benang yang patut diterokai. Antara muka yang kurang dikenali ini boleh diimport menggunakan kelas ThreadPool daripada modul multiprocessing.pool:

from multiprocessing.pool import ThreadPool
Salin selepas log masuk

Di sebalik tabir, kelas ThreadPool ini menggunakan kelas Proses dummy yang membalut benang Python. Kelas Proses dummy ini dilaksanakan dalam modul multiprocessing.dummy, yang menawarkan antara muka berbilang pemprosesan yang lengkap berdasarkan urutan.

Contoh Penggunaan:

Untuk menggunakan ThreadPool, instantiate objek ThreadPool dengan bilangan benang pekerja yang dikehendaki. Kemudian, gunakan kaedah peta untuk menyelaraskan fungsi merentas urutan pekerja.

# Create a ThreadPool with 4 worker threads
pool = ThreadPool(4)

# Parallelize the `long_running_func` on 100 inputs
results = pool.map(long_running_func, range(100))
Salin selepas log masuk

Atas ialah kandungan terperinci Bilakah Saya Harus Menggunakan ThreadPool Python Daripada Multiprocessing.Pool?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan