Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah saya boleh menyelaraskan Gelung Python Mudah untuk Mengatasi Had GIL?

Bagaimanakah saya boleh menyelaraskan Gelung Python Mudah untuk Mengatasi Had GIL?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-30 14:49:11453semak imbas

How Can I Parallelize Simple Python Loops to Overcome the GIL Limitation?

Menyelaraskan Gelung Python Mudah

Kunci jurubahasa global (GIL) dalam CPython menghalang pelaksanaan serentak kod Python oleh berbilang urutan. Oleh itu, penggunaan proses adalah lebih berkesan untuk beban kerja terikat CPU seperti yang dipamerkan dalam gelung sampel.

Pustaka standard Python menyediakan dua kaedah mudah untuk mencipta kumpulan proses:

1 . Modul berbilang pemprosesan:

pool = multiprocessing.Pool(4)
out1, out2, out3 = zip(*pool.map(calc_stuff, range(0, 10 * offset, offset)))

2. concurrent.futures.ProcessPoolExecutor:

with concurrent.futures.ProcessPoolExecutor() as pool:
    out1, out2, out3 = zip(*pool.map(calc_stuff, range(0, 10 * offset, offset)))

Menggunakan kedua-dua kaedah, fungsi calc_stuff dilaksanakan secara selari dan hasilnya dikumpulkan ke dalam senarai output out1, out2, dan out3. Pendekatan ini secara berkesan menyamakan pengiraan dan menggunakan berbilang pemproses pada sistem.

Atas ialah kandungan terperinci Bagaimanakah saya boleh menyelaraskan Gelung Python Mudah untuk Mengatasi Had GIL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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