0

0

Python怎么运行协程_不可直接调用协程对象需通过await或run执行的常见报错处理

P粉602998670

P粉602998670

发布时间:2026-03-17 10:43:03

|

530人浏览过

|

来源于php中文网

原创

直接调用协程函数未await会触发RuntimeWarning,因协程对象未被驱动执行;须在async函数中用await,或在同步环境中用asyncio.run()调度,且不可在非async函数中使用await。

python怎么运行协程_不可直接调用协程对象需通过await或run执行的常见报错处理

直接调用协程函数却没 await,报 RuntimeWarning: coroutine 'xxx' was never awaited

Python 协程函数返回的是一个协程对象(coroutine),不是普通函数,不能像 func() 这样直接调用完就结束。你看到的警告,本质是 Python 在垃圾回收时发现这个协程对象创建后既没 await 也没被 asyncio.run() 等驱动执行,就主动提醒你“漏了”。

常见触发场景:

  • 在同步函数里写了 my_coro(),但没加 await
  • if 分支或循环里构造了协程对象,但某些路径下没 await
  • 误把协程当普通函数传给 map()list comprehension 等,结果只生成一堆未执行的 coroutine 对象

实操建议:

  • 确认所在作用域是否为 async def 函数内:如果是,必须用 await my_coro();如果不是,得用 asyncio.run(my_coro())asyncio.create_task() 等方式调度
  • 检查缩进和条件逻辑——尤其注意 else 分支或异常处理中是否遗漏 await
  • isinstance(my_coro(), types.CoroutineType) 快速验证返回值类型(需先 import types

在非 async 函数里运行协程,必须用 asyncio.run() 而不是 loop.run_until_complete()

asyncio.run() 是 Python 3.7+ 推荐的顶层入口,它会自动创建新事件循环、运行协程、清理资源并关闭循环。而手动调用 loop.run_until_complete() 容易出问题,尤其在多次调用或已有运行中循环的环境里。

立即学习Python免费学习笔记(深入)”;

典型错误现象:

  • 第二次调用 loop.run_until_complete()RuntimeError: This event loop is already running
  • 脚本退出后出现 ResourceWarning: unclosed transport
  • Jupyter 中反复执行单元格后协程卡住或不响应

实操建议:

  • 脚本主入口一律用 asyncio.run(main()),别碰 get_event_loop()run_until_complete()
  • 如果真要复用循环(如嵌入到已有异步框架中),优先用 asyncio.create_task() 把协程提交给当前运行的循环,而不是自己启停
  • 避免在函数内部反复调用 asyncio.run() —— 它每次都会新建循环,开销大且可能冲突;应把多个协程合并成一个顶层协程再跑

await 只能在 async def 函数里用,否则报 SyntaxError: invalid syntax

这是语法层面限制:await 是关键字,解析器只允许它出现在 async def 定义的函数体中。哪怕只差一层缩进、少写一个 async,就会直接报错,连解释器都过不去。

HIX Translate
HIX Translate

由 ChatGPT 提供支持的智能AI翻译器

下载

容易踩的坑:

  • 想在普通函数里写 await asyncio.sleep(1),结果 SyntaxError
  • 复制粘贴协程代码时漏掉开头的 async,或者把 async def 错打成 def
  • 在类方法中用了 await,但忘记给方法加 async(即使类本身继承自 AsyncContextManager 也不行)

实操建议:

  • 编辑器开启 Python 语法高亮和 lint(如 Pylint、Ruff),这类错误能实时标红
  • 不要试图“绕过”这个限制——比如用 exec() 拼字符串、或用 asyncio.run() 包一层来模拟“同步 await”,这只会让逻辑更难追踪
  • 若需在同步上下文中触发异步逻辑,明确拆成两层:上层同步封装(如返回 Future 或启动任务),下层才是真正的 async def

协程里调用阻塞函数(如 time.sleeprequests.get)会导致整个事件循环卡死

协程并发靠的是“让出控制权”,不是多线程。一旦在 async def 函数里调用纯同步阻塞操作,当前协程会一直占着事件循环不放,其他协程全得等着——表面是异步,实际串行,还失去并发优势。

典型表现:

  • 多个 await asyncio.sleep(1) 总耗时约 1 秒,但换成 time.sleep(1) 后变成 3 秒(3 个串行)
  • requests.get() 替代 aiohttp.ClientSession.get(),QPS 不升反降

实操建议:

  • 网络请求统一换 aiohttphttpx.AsyncClient 等异步库
  • CPU 密集型操作(如 JSON 解析、加密)用 loop.run_in_executor() 扔到线程池,避免阻塞事件循环
  • 文件读写优先用 aiopathanyio.Path,而不是内置 open()
  • 调试时可在协程开头加 print(f"start at {time.time():.2f}"),对比 time.sleepasyncio.sleep 的时间戳差异,快速定位阻塞点

协程不是魔法,它只解决 I/O 等待的并发问题。真正卡住循环的,永远是那些你以为“很快”、其实根本没让出控制权的调用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

458

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

84

2025.09.10

python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.09.27

python print用法与作用
python print用法与作用

本专题整合了python print的用法、作用、函数功能相关内容,阅读专题下面的文章了解更多详细教程。

19

2026.02.03

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号