Rumah > pembangunan bahagian belakang > Tutorial Python > Bagaimanakah Saya Boleh Mendapatkan Kembali Nilai daripada multiprocessing.Process Instance dalam Python?

Bagaimanakah Saya Boleh Mendapatkan Kembali Nilai daripada multiprocessing.Process Instance dalam Python?

Patricia Arquette
Lepaskan: 2024-11-28 11:48:12
asal
599 orang telah melayarinya

How Can I Retrieve Return Values from multiprocessing.Process Instances in Python?

Mengekstrak Nilai Pulangan daripada Fungsi dalam Multiprocessing.Process Instance

Keupayaan untuk mendapatkan kembali nilai pulangan daripada fungsi yang dihantar kepada multiprocessing.Proses boleh menjadi ciri yang berguna, terutamanya apabila pelaksanaan tugas tak segerak diperlukan. Malangnya, nilai itu tidak boleh diakses serta-merta daripada objek Proses, memerlukan pendekatan alternatif.

Memahami Storan Nilai

Tidak seperti fungsi Python tradisional, fungsi tersebut dihantar ke multiprocessing.Process tidak mempunyai atribut nilai pulangan. Sebaliknya, nilai disimpan di lokasi yang berasingan, khususnya dalam objek memori yang dikongsi. Ini kerana proses yang dibuat menggunakan pemproses berbilang dijalankan dalam ruang memori yang berasingan, menghalang akses terus kepada pembolehubah dalam proses utama.

Menggunakan Pembolehubah Dikongsi untuk Komunikasi

Untuk mengakses nilai pulangan, kita perlu mewujudkan satu bentuk komunikasi antara proses. Satu kaedah yang berkesan ialah menggunakan pembolehubah yang dikongsi. Ini adalah objek yang membenarkan berbilang proses berkongsi dan mengakses data secara serentak. Dalam kes kami, kami mencipta objek pengurus dan kamus kongsi menggunakan multiprocessing.Manager(). Kamus bertindak sebagai pembolehubah kongsi.

Mengakses Nilai Pulangan

Dalam fungsi pekerja, kami mengisi kamus kongsi dengan nilai pulangan yang diingini. Proses utama, selepas menunggu semua tugasan selesai, boleh mengakses dan mendapatkan semula nilai ini daripada kamus kongsi. Dengan menggunakan strategi ini, kami mengekstrak nilai pulangan secara berkesan tanpa menjejaskan pendekatan berbilang pemprosesan.

Contoh Pelaksanaan

Contoh berikut mempamerkan pelaksanaan pembolehubah dikongsi untuk mendapatkan pulangan nilai:

import multiprocessing

def worker(procnum, return_dict):
    """worker function"""
    print(str(procnum) + " represent!")
    return_dict[procnum] = procnum

if __name__ == "__main__":
    manager = multiprocessing.Manager()
    return_dict = manager.dict()
    jobs = []
    for i in range(5):
        p = multiprocessing.Process(target=worker, args=(i, return_dict))
        jobs.append(p)
        p.start()

    for proc in jobs:
        proc.join()
    print(return_dict.values())
Salin selepas log masuk

Output:

0 represent!
1 represent!
3 represent!
2 represent!
4 represent!
[0, 1, 3, 2, 4]
Salin selepas log masuk

Pendekatan ini membolehkan kami mendapatkan semula nilai pulangan fungsi pekerja dan menunjukkan komunikasi yang lancar antara proses dalam rangka kerja berbilang pemprosesan.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mendapatkan Kembali Nilai daripada multiprocessing.Process Instance dalam Python?. 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