信息发布→ 登录 注册 退出

Python asyncio 中的异常捕获技巧

发布时间:2025-11-20

点击量:
使用 try-except 捕获 await 异常,create_task 需显式 await 或检查异常,gather 默认中断任务但可配置,wait 需手动检查,全局处理器用于监控未捕获异常。

python asyncio 中的异常捕获技巧

在使用 Python 的 asyncio 编程时,异常处理比同步代码更复杂。协程可能在事件循环中异步执行,异常不会自动冒泡到主线程,若不妥善处理,会导致程序静默失败或资源泄漏。掌握正确的异常捕获方式,是编写健壮异步应用的关键。

直接 await 协程时的异常捕获

当你直接调用并 await 一个协程对象时,可以像处理普通函数一样使用 try-except 捕获异常。

  • 协程内部抛出的异常会在 await 表达式处重新抛出
  • 使用 try-except 包裹 await 语句即可捕获

示例:

import asyncio
<p>async def risky_task():
await asyncio.sleep(1)
raise ValueError("出错了")</p><p>async def main():
try:
await risky_task()
except ValueError as e:
print(f"捕获异常: {e}")</p><p>asyncio.run(main())

通过 create_task 启动任务的异常处理

使用 asyncio.create_task() 创建的任务会在后台运行,即使协程抛出异常,也不会立即被捕获。必须显式等待任务或检查其状态。

  • 未被 await 的任务异常会滞留在任务对象中
  • 任务异常只有在调用 result() 或 await 时才会触发

正确做法:保留任务引用并在合适时机 await 或检查异常。

async def main():
    task = asyncio.create_task(risky_task())
    try:
        await task
    except ValueError as e:
        print(f"任务异常: {e}")

如果不 await 任务,异常可能直到程序结束才被打印(通过 loop.set_exception_handler 可定制行为)。

并发执行中的异常捕获(gather 与 wait)

当需要同时运行多个协程时,常用 asyncio.gatherasyncio.wait,它们对异常的处理方式不同。

Python v2.4 中文手册 chm Python v2.4 中文手册 chm

Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。

Python v2.4 中文手册 chm 2 查看详情 Python v2.4 中文手册 chm

asyncio.gather 默认遇到第一个异常就停止其他任务(可配置 return_exceptions=True 改变行为):

async def main():
    try:
        await asyncio.gather(
            good_task(),
            risky_task()
        )
    except ValueError as e:
        print(f"Gather 捕获: {e}")  # 立即中断

开启 return_exceptions=True 后,异常作为结果返回,不会中断其他任务:

results = await asyncio.gather(
    good_task(),
    risky_task(),
    return_exceptions=True
)
for r in results:
    if isinstance(r, Exception):
        print(f"任务异常: {r}")

asyncio.wait 返回完成和未完成的任务集合,需手动检查每个完成任务的异常:

done, pending = await asyncio.wait([task1, task2], return_when=asyncio.FIRST_EXCEPTION)
for t in done:
    if t.exception():
        print(f"任务出错: {t.exception()}")

全局异常处理器

可以通过设置事件循环的异常处理器来捕获未被处理的任务异常。

def custom_exception_handler(loop, context):
    msg = context.get("exception", context["message"])
    print(f"全局捕获异常: {msg}")
<p>loop = asyncio.get_event_loop()
loop.set_exception_handler(custom_exception_handler)

这适用于监控后台任务的意外崩溃,但不能替代正常的异常处理逻辑。

基本上就这些。关键是要意识到 async/await 中的异常不会自动传播,必须主动 await 任务或检查其结果。合理使用 try-except、gather 的参数以及全局处理器,才能构建可靠的异步系统。

以上就是Python asyncio 中的异常捕获技巧的详细内容,更多请关注其它相关文章!


相关文章: 漫画星球免费下拉式入口 漫画星球免费漫画在线阅读网站  深入理解J*aScript中的B样条曲线与节点向量生成  steam官方网页快速访问 steam账号注册全流程  Golang如何处理RPC请求负载均衡_Golang RPC请求负载均衡策略与实践  MAC的“快捷指令”怎么同步到iPhone_MAC利用iCloud同步所有设备的自动化指令  汽水音乐在线解析 汽水音乐在线解析入口  c++如何使用TBB库进行任务并行_c++ Intel线程构建模块  C++如何生成随机数_C++ random库使用方法与范围设置  cad如何更改注释性对象的比例_cad注释性比例调整方法  在J*a中如何开发简易仓库管理与库存统计_仓库管理库存统计项目实战解析  极兔快递快件信息查询系统 极兔快递官网运单号追踪  msn官网入口地址手机版 msn官方网站手机最新链接  J*aScript生成器_j*ascript异步迭代  魅族17怎样用浏览器译外语网页_iPhone魅族17浏览器译外语网页【即时翻译】  “音游” × “怪文书” 题材的节奏冒险游戏 《晕晕电波症候群》确定于2026年4月发售!  J*aScript map 方法中处理循环元素为空数组的策略  我的世界mc.js免费游戏直接能玩 我的世界mc.js小游戏免费秒玩入口  怎么去除衣服上的口红印_生活小妙招教你用酒精轻松擦除  Lar*el DB::listen 事件中的查询执行时间单位解析  深入理解J*aScript Promise异步执行与微任务队列  星露谷物语官网入口 星露谷物语游戏官网入口  J*aScript实现单选按钮与关联输入框的联动禁用教程  钉钉视频会议画面卡顿如何解决 钉钉会议画面优化方法  KFC游戏互动怎么赢取优惠券_KFC线上游戏活动参与与优惠代码赢取教程  Yandex官方入口网址 Yandex俄罗斯搜索引擎最新在线地址  mysql如何设置表访问权限_mysql表访问权限配置  Highcharts 雷达图径向轴标签定制指南:利用多Y轴实现数值标注  J*aScript设计模式实践_j*ascript代码优化  解决Python单元测试中Mock异常方法调用计数为零的问题  在VS Code中配置和运行Dart程序的完整步骤  深入理解Go语言中Map值与方法接收器的交互:为什么需要临时变量  在Runstone环境中高效处理TasteDive API的JSON数据  Composer的 COMPOSER_PROCESS_TIMEOUT 配置项有什么用_解决因执行时间过长而失败的Composer脚本  漫蛙2在线漫画入口 漫蛙正版漫画网页版直达  mysql备份恢复性能优化_mysql备份恢复性能优化方法  在Google App Engine Go中实现独立模块代码库与灵活路由  qq游戏跨平台入口_qq游戏多设备同步登录  解决Tabulator日期时间排序问题的专业指南  PS5 Pro有点优势但不多! 《燕云十六声》PS5平台与PC性能画面对比  Win11怎么查看显卡显存 Win11显示适配器属性及专用视频内存查询  163邮箱登录密码 163邮箱忘记密码找回  利用5118提升短视频内容效果_5118短视频关键词优化方法  天猫2025双十一0点秒杀攻略 天猫爆款抢购时间  Win11怎么设置鼠标主按键_Win11鼠标左右键功能互换  如何将HTML表格多行数据保存到Google Sheets  Lar*el 递归关系中排除指定分支的教程  电脑屏幕颜色不舒服怎么办_Windows夜间模式与色彩校准教程【护眼技巧】  163邮箱网页版入口导航平台 163邮箱网页版登录入口官网导航  Python实现多节点属性重叠度分析教程  PHP中SSG-WSG API的AES加密实践:正确使用初始化向量 

在线客服
服务热线

服务热线

4008988990

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!