verlassen Ich habe ein asyncio/Python-Programm mit zwei asyncio Aufgaben:Python asyncio Programm nicht
- eine, die
- man stürzt, die immer weitergeht.
Ich möchte mein gesamtes Programm nach dem ersten Absturz beenden. Ich kann es nicht passieren.
import asyncio
import time
def infinite_while():
while True:
time.sleep(1)
async def task_1():
await asyncio.sleep(1)
assert False
async def task_2():
loop = asyncio.get_event_loop()
await loop.run_in_executor(None, lambda: infinite_while())
loop = asyncio.get_event_loop()
asyncio.set_event_loop(loop)
tasks = asyncio.gather(task_2(), task_1())
try:
loop.run_until_complete(tasks)
except (Exception, KeyboardInterrupt) as e:
print('ERROR', str(e))
exit()
Es wird Fehler ausgegeben, aber nicht beendet. Wenn manuell geschlossen, druckt das Programm den folgenden Stack-Trace:
Error in atexit._run_exitfuncs:
Traceback (most recent call last):
File "/usr/lib/python3.5/concurrent/futures/thread.py", line 39, in _python_exit
t.join()
File "/usr/lib/python3.5/threading.py", line 1054, in join
self._wait_for_tstate_lock()
File "/usr/lib/python3.5/threading.py", line 1070, in _wait_for_tstate_lock
elif lock.acquire(block, timeout):
KeyboardInterrupt
Haben Sie versucht, kooperativ zu beenden? Wahrscheinlich nicht, was Sie wollen, aber zumindest als Experiment könnten Sie: die Schleife in 'infinite_while' ändern, um' while not exit_requested' zu sagen; Ändern Sie 'task_1', um die Assertion-Ausnahme abzufangen, setzen Sie das Flag und reraise; und sehen Sie, ob Ihr Aufruf von exit() beendet wird, sobald jeder Task beendet wurde, einen normalen und einen mit der Assertion-Ausnahme. –
Danke, es funktioniert, wird es als letzten Ausweg nutzen, aber ich hoffe, es gibt einen saubereren Weg, es zu lösen. – MrJ