Почему asyncio.gather() не отменяет ожидающие задачи в случае сбоя одной задачи?Python

Программы на Python
Ответить
Anonymous
 Почему asyncio.gather() не отменяет ожидающие задачи в случае сбоя одной задачи?

Сообщение Anonymous »

Я использую asyncio.gather для параллельного запуска нескольких сопрограмм. Когда одна сопрограмма вызывает исключение, я ожидаю, что остальные задачи будут отменены. Однако они продолжают работать.
import asyncio

async def worker(id):
await asyncio.sleep(1)
if id == 2:
raise ValueError("Failing task")
return id

async def main():
tasks = [worker(i) for i in range(5)]
try:
await asyncio.gather(*tasks)
except Exception as e:
print("Error:", e)

asyncio.run(main())


Подробнее здесь: https://stackoverflow.com/questions/798 ... task-fails
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»