Bagaimana untuk Berkongsi Barisan Hasil Antara Pelbagai Proses dalam Python?

Susan Sarandon
Lepaskan: 2024-10-19 18:45:02
asal
620 orang telah melayarinya

How to Share a Result Queue Between Multiple Processes in Python?

Cara Berkongsi Barisan Hasil Antara Pelbagai Proses

Apabila bekerja dengan proses pekerja tak segerak menggunakan modul pemprosesan berbilang apply_async () fungsi, adalah penting untuk mempertimbangkan cara berkongsi baris gilir dengan selamat. Ralat "RuntimeError: Objek baris gilir hanya perlu dikongsi antara proses melalui warisan" menyerlahkan keperluan untuk melepasi baris gilir dengan cara yang menghalang isu penjerukan/nyahjeruk.

Untuk menyelesaikannya, kami boleh memanfaatkan pemproses berbilang.Pengurus () kelas, yang menyediakan cara untuk mengurus objek dan menjadikannya boleh diakses oleh pekerja yang berbeza.

<code class="python">import multiprocessing

def worker(name, que):
    que.put("%d is done" % name)

if __name__ == '__main__':
    pool = multiprocessing.Pool(processes=3)
    m = multiprocessing.Manager()
    q = m.Queue()
    workers = pool.apply_async(worker, (33, q))</code>
Salin selepas log masuk

Dalam contoh ini, kami mencipta objek Pengurus (m) dan menggunakannya untuk menguruskan baris gilir (q). Dengan berbuat demikian, kami mencipta segmen memori kongsi yang membenarkan berbilang proses mengakses baris gilir dengan selamat, walaupun dalam senario tak segerak.

Atas ialah kandungan terperinci Bagaimana untuk Berkongsi Barisan Hasil Antara Pelbagai Proses dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!