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())
Output:
0 represent! 1 represent! 3 represent! 2 represent! 4 represent! [0, 1, 3, 2, 4]
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!