


Bagaimanakah Saya Boleh Mendapatkan Kembali Nilai daripada multiprocessing.Process Instance dalam Python?
Nov 28, 2024 am 11:48 AMMengekstrak 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!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?

Cara Menggunakan Python untuk Mencari Pengagihan Zipf Fail Teks

Cara Bekerja Dengan Dokumen PDF Menggunakan Python

Cara Cache Menggunakan Redis dalam Aplikasi Django

Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?

Memperkenalkan Toolkit Bahasa Alam (NLTK)
