Heim > Backend-Entwicklung > Python-Tutorial > Wie rufe ich Rückgabewerte von Multiprocessing.Process-Funktionen in Python ab?

Wie rufe ich Rückgabewerte von Multiprocessing.Process-Funktionen in Python ab?

Mary-Kate Olsen
Freigeben: 2024-12-02 19:07:26
Original
553 Leute haben es durchsucht

How to Retrieve Return Values from Multiprocessing.Process Functions in Python?

Zugriff auf den Rückgabewert einer Funktion in Multiprocessing.Process

Beim Multiprocessing mit Python das Abrufen des Rückgabewerts einer an Multiprocessing übergebenen Funktion. Der Prozess kann schwierig sein, da er nicht direkt im Prozessobjekt gespeichert wird.

Bedenken Sie Folgendes Beispiel:

import multiprocessing

def worker(procnum):
    '''worker function'''
    print(str(procnum) + ' represent!')
    return procnum


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

    for proc in jobs:
        proc.join()
    print(jobs)
Nach dem Login kopieren

Während dieser Code die Ausgabe jedes Arbeitsprozesses ausgibt, können wir nicht direkt auf deren Rückgabewerte zugreifen.

Um die Rückgabewerte abzurufen, können wir eine gemeinsam genutzte Variable verwenden. Im folgenden überarbeiteten Code wird ein Manager() aus dem Multiprocessing-Modul verwendet, um ein gemeinsames Wörterbuch zu erstellen:

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())
Nach dem Login kopieren

Hier aktualisiert jeder Arbeitsprozess das gemeinsame Wörterbuch return_dict mit seinem Rückgabewert. Der Hauptprozess kann dann auf diese Werte aus dem freigegebenen Wörterbuch zugreifen.

Das obige ist der detaillierte Inhalt vonWie rufe ich Rückgabewerte von Multiprocessing.Process-Funktionen in Python ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage