Tastatur-Interrupts mit dem Multiprocessing-Pool von Python
Wie kann ich KeyboardInterrupt-Ereignisse mit Pythons Multiprocessing-Pools behandeln? Hier ist ein einfaches Beispiel:
from multiprocessing import Pool
from time import sleep
from sys import exit
def slowly_square(i):
sleep(1)
return i*i
def go():
pool = Pool(8)
try:
results = pool.map(slowly_square, range(40))
except KeyboardInterrupt:
# **** THIS PART NEVER EXECUTES. ****
pool.terminate()
print "You cancelled the program!"
sys.exit(1)
print "\nFinally, here are the results: ", results
if __name__ == "__main__":
go()
Wenn Sie den obigen Code ausführen, wird dasKeyboardInterrupt
wird angehoben, wenn ich drücke^C
, aber der Prozess hängt einfach an diesem Punkt und ich muss es extern töten.
Ich möchte in der Lage sein zu drücken^C
Sie können jederzeit alle Prozesse ordnungsgemäß beenden.