Python asyncio入门教程_Python asyncio如何实现异步IO并发

admin 百科 19
Python asyncio通过事件循环调度协程实现异步IO并发,核心是“让出控制权+高效复用线程”;async/await定义和等待协程,asyncio.run()启动程序,create_task()/gather()实现并发,需配合httpx、aiofiles等异步库使用。

Python asyncio入门教程_Python asyncio如何实现异步IO并发-第1张图片-佛山资讯网

Python asyncio 是实现异步 IO 并发的核心模块,它通过事件循环(event loop)调度协程(coroutine),让单线程在等待 IO(如网络请求、文件读写)时不阻塞,转而执行其他任务,从而提升并发性能。关键不在于“多线程”或“多进程”,而在于“让出控制权 + 高效复用线程”。

async/await 是协程的语法基础

async def 定义协程函数,调用后返回协程对象,不会立即执行;await 用于挂起当前协程,等待另一个协程(或可等待对象)完成,并把控制权交还给事件循环。

  • 普通函数用 def,协程函数必须用 async def
  • await 只能在 async 函数内部使用,不能出现在普通函数里
  • 常见的可等待对象包括:协程、asyncio.Task、asyncio.Future,以及实现了 __await__ 方法的对象

asyncio.run() 是最简单的入口

它自动创建事件循环、运行协程、关闭循环,适合脚本和入门示例。一个协程运行完毕后,整个程序就退出。

import asyncioasync def say_after(delay, text):
await asyncio.sleep(delay)
print(text)async def main():
await say_after(1, 'Hello')
await say_after(2, 'World')asyncio.run(main())  # 输出:先 Hello,1秒后 World(串行)

登录后复制

并发执行用 asyncio.create_task() 或 asyncio.gather()

如果想让多个协程“同时”运行(即并发,非并行),不能用 await 逐个等待,而要提前调度它们。

标签: mysql python ai 标准库

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~