asyncio.gather()是一个非常有用的函数,可以在异步代码中同时运行多个协程并收集结果。但是,它的异常处理方法可能不是很直观,特别是在高级协程分组的情况下。
当我们使用asyncio.gather来同时运行多个协程时,如果其中一个协程出现异常,则asyncio.gather会立即停止所有协程并引发首个异常。这个异常可能是调用asyncio.gather的代码中未处理的异常,也可能是协程中的异常。
如果我们需要对每个协程的异常进行个性化处理,则需要对每个协程进行单独的异常处理。下面是一个示例:
import asyncio
async def func1():
raise ValueError("Error in func1")
async def func2():
raise TypeError("Error in func2")
async def func3():
raise Exception("Error in func3")
async def main():
tasks = [func1(), func2(), func3()]
try:
for task in asyncio.as_completed(tasks):
result = await task
except ValueError as e:
print(f"Error in func1: {e}")
except TypeError as e:
print(f"Error in func2: {e}")
except Exception as e:
print(f"Error in func3: {e}")
asyncio.run(main())
在这个示例中,我们使用了asyncio.as_completed()来按照它们完成的顺序获取每个任务。然后,我们可以使用try/except语句来捕获每个协程的异常并进行个性化处理。
尽管这个示例中使用的是as_completed(),但也可以使用asyncio.wait()或asyncio.gather()在每个任务之间迭代。
例如,下面是使用asyncio.gather()的示例,对每个协程的异常进行分别处理:
import asyncio
async def func1():
上一篇:asyncio.gather在调用者从STDIN请求输入时无法执行任务?
下一篇:asyncio.get_event_loop().run_until_complete(asyncio.sleep(1))的含义是什么?