Tastaturunterbrechungen in Multiprocessing -Pools mit Python
Die Handhabung von KeyboarTinrups ist für die Verwaltung paralleler Prozesse effektiv. Die Multiprocessing -Bibliothek bietet eine Möglichkeit, einen Pool von Arbeitsprozessen zu erstellen, mit denen Aufgaben gleichzeitig ausgeführt werden können. Es entsteht jedoch ein Problem, wenn während der Ausführung dieser Prozesse ein Tastaturinterrupt initiiert wird. Der entsprechende Code innerhalb des außer Blocks wird jedoch niemals ausgeführt, so dass das Programm hängen bleibt.
versuchen: Ergebnisse = Pool.Map (langsam_Square, Bereich (40)) Außer Tastaturinterruhrter: pool.terate () print ("Sie haben das Programm storniert!") sys.exit (1)
cause:
try:
results = pool.map(slowly_square, range(40))
except KeyboardInterrupt:
pool.terminate()
print("You cancelled the program!")
sys.exit(1)
Lösung:
, um dieses Problem zu lösen, um eine Zeitüberschreitung zu spezifizieren, wenn sie auf die Ergebnisse warten. Dies kann erreicht werden, indem der MAP () -Rall durch map_async () ersetzt wird. Get (Timeout), wobei Timeout auf einen großen Wert eingestellt ist. Keyboarderrupt wurde nicht verarbeitet. Dies ermöglicht dem Ausnahme des Blocks auszuführen, und ermöglicht die Beendigung des Pools und den anmutigen Umgang mit dem Interrupt.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3