asyncio是Python标准库,基于事件循环和协程,适用于异步Web服务、爬虫等;2. Tornado是独立异步网络库,内置高性能服务器,适合实时通信场景;选择取决于需求。

Python实现异步编程主要依赖于两种框架:asyncio 和 Tornado。它们都能处理高并发I/O操作,但设计思路和使用场景略有不同。
asyncio 是 Python 标准库中用于编写单线程并发代码的模块,基于 事件循环(Event Loop) 和 协程(Coroutine) 实现异步编程。
它从 Python 3.4 开始引入,3.5 以后通过 async/await 语法让异步代码更简洁易读。
使用 asyncio 的基本方式包括:
立即学习“Python免费学习笔记(深入)”;
示例代码:
import asyncio
<p>async def fetch_data():
print("开始获取数据")
await asyncio.sleep(2) # 模拟异步等待
print("数据获取完成")
return {"data": 123}</p><p>async def main():
task = asyncio.create_task(fetch_data())
print("正在做其他事...")
result = await task
print(result)</p><p>asyncio.run(main())</p>asyncio 常用于构建异步 Web 服务(如 FastAPI、aiohttp)、爬虫、消息队列客户端等。
Tornado 是一个独立的 Python 异步网络库,最初为 Web 服务设计,自带 Web 框架和高性能 HTTP 服务器。
它不仅支持异步处理请求,还原生支持长连接(如 WebSocket)和实时服务。
Tornado 的异步机制早期基于回调(callback),后来也兼容 async/await 语法。
它的核心是自己的事件循环,可以替代 asyncio(也可与之集成)。
简单示例:
import tornado.ioloop
import tornado.web
import tornado.gen
<p>class MainHandler(tornado.web.RequestHandler):
async def get(self):
await tornado.gen.sleep(2)
self.write("Hello, 异步世界!")</p><p>def make_app():
return tornado.web.Application([
(r"/", MainHandler),
])</p><p>if <strong>name</strong> == "<strong>main</strong>":
app = make_app()
app.listen(8888)
print("服务运行在 <a href="https://www.php.cn/link/4f10ac32425eaa39b2f93cd9c67ff456">https://www.php.cn/link/4f10ac32425eaa39b2f93cd9c67ff456</a>")
tornado.ioloop.IOLoop.current().start()</p>Tornado 更适合需要长时间保持连接的场景,比如实时聊天、推送服务等。
基本上就这些。asyncio 是现代 Python 异步的主流选择,而 Tornado 在特定场景下仍有优势,尤其是需要内置高性能服务器和 WebSocket 支持时。选择哪个取决于项目需求和生态依赖。不复杂但容易忽略的是:理解事件循环的运行机制,才能真正掌握这两种框架的使用。
以上就是python实现异步的两种框架的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号