登录
首页 >  文章 >  python教程

Python异步编程中有哪些常见陷阱_总结await位置不对导致的性能坑

时间:2026-05-03 15:24:42 240浏览 收藏

最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《Python异步编程中有哪些常见陷阱_总结await位置不对导致的性能坑》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~

await位置错误会导致异步退化为同步:循环内await使请求串行,应改用asyncio.gather并发;非async函数中需用asyncio.run()或await调用;不可await非awaitable对象,如time.sleep或requests.get。

Python异步编程中有哪些常见陷阱_总结await位置不对导致的性能坑

await位置不对不会直接报错,但会让异步代码退化成同步执行,完全失去并发优势。

await写在循环里导致串行执行

想并发请求 10 个 URL,却把 await 放在 for 循环内部,结果是逐个等待,总耗时 ≈ 所有请求时间之和。

  • 错误写法:for url in urls: data = await fetch(url) → 每次都等上一个完成才发下一个
  • 正确做法:先生成所有协程对象,再用 asyncio.gather() 统一并发等待:results = await asyncio.gather(*[fetch(u) for u in urls])
  • 注意:gather() 中传的是协程对象(fetch(u)),不是函数名(fetch);传错会报 TypeError: an asyncio.Future, a coroutine or an awaitable is required

在非 async 函数里漏掉 await 或 asyncio.run()

常见于脚本顶层或 Flask/Django 视图中直接调用 async def 函数,比如写 result = my_coro(),它只返回一个 ,逻辑根本不执行。

  • 现象:程序“没反应”、打印出 、或触发 RuntimeWarning: coroutine 'xxx' was never awaited
  • 脚本顶层:必须用 asyncio.run(my_coro())
  • 已运行事件循环的环境(如 FastAPI、Jupyter):改用 await my_coro(),不能用 asyncio.run(),否则报 RuntimeError: asyncio.run() cannot be called from a running event loop
  • 同步函数里要调异步逻辑:用 asyncio.get_event_loop().run_until_complete(my_coro())(Python 3.7+),或封装进线程池(asyncio.to_thread()

await了不该 await 的东西

比如对 CPU 密集型操作加 await,或误 await 一个普通函数、字符串、数字——这些都不是 awaitable,会直接报 TypeError

  • 典型错误:await time.sleep(1)time.sleep 是同步阻塞,且不是协程,不能 await;应换 await asyncio.sleep(1)
  • 更隐蔽的:await requests.get(...)requests 是同步库,返回 Response 对象,不是协程;得换 aiohttphttpx.AsyncClient
  • 调试技巧:启用 asyncio 调试模式,asyncio.run(main(), debug=True),能捕获长时间阻塞并警告

最易被忽略的是:await 本身不解决 CPU 瓶颈,只释放 I/O 等待期间的控制权。如果协程里混着大循环、正则匹配、JSON 解析等计算密集操作,整个事件循环会被卡住——这时候得用 loop.run_in_executor() 拆出去,而不是盲目加 await。

理论要掌握,实操不能落!以上关于《Python异步编程中有哪些常见陷阱_总结await位置不对导致的性能坑》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>