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

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 逐个等待,而要提前调度它们。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~