Mam asyncio programu/Python z dwoma asyncio zadań:Python asyncio programu nie wypłynie
- taki, który rozbija
- , który trwa przez wieki.
Chcę, aby mój cały program zakończył się po pierwszej awarii. Nie mogę tego zrobić.
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()
Drukuje BŁĄD, ale nie wychodzi. Przy ręcznym zamknięciu program drukuje następujące ślad stosu:
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
Czy próbowałeś wyjść ze współpracy? Prawdopodobnie nie to, czego chcesz, ale przynajmniej jako eksperyment, możesz: zmienić pętlę w 'infinite_while', aby wypowiedzieć' while not exit_requested'; zmień 'task_1', aby wychwycić wyjątek asercji, ustawić flagę i przebić; i zobacz, czy wywołanie funkcji exit() kończy się po zakończeniu każdego zadania, jeden zwykle i jeden z wyjątkiem potwierdzenia. –
Dzięki, działa, użyje go w ostateczności, ale ma nadzieję, że istnieje czystszy sposób rozwiązania. – MrJ