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

Python实现异步编程主要依赖于两种框架:asyncio 和 Tornado。它们都能处理高并发I/O操作,但设计思路和使用场景略有不同。
1. asyncio 框架
asyncio 是 Python 标准库中用于编写单线程并发代码的模块,基于 事件循环(Event Loop) 和 协程(Coroutine) 实现异步编程。
它从 Python 3.4 开始引入,3.5 以后通过 async/await 语法让异步代码更简洁易读。
使用 asyncio 的基本方式包括:
立即学习“Python免费学习笔记(深入)”;
用 async def 定义协程函数用 await 调用其他协程或异步 I/O 操作通过 asyncio.run() 启动事件循环(Python 3.7+)
示例代码:
import asyncioasync def fetch_data():print("开始获取数据")await asyncio.sleep(2) # 模拟异步等待print("数据获取完成")return {"data": 123}
async def main():task = asyncio.create_task(fetch_data())print("正在做其他事...")result = await taskprint(result)
asyncio.run(main())
asyncio 常用于构建异步 Web 服务(如 FastAPI、aiohttp)、爬虫、消息队列客户端等。
2. Tornado 框架
Tornado 是一个独立的 Python 异步网络库,最初为 Web 服务设计,自带 Web 框架和高性能 HTTP 服务器。
它不仅支持异步处理请求,还原生支持长连接(如 WebSocket)和实时服务。
Tornado 的异步机制早期基于回调(callback),后来也兼容 async/await 语法。
它的核心是自己的事件循环,可以替代 asyncio(也可与之集成)。
简单示例:
import tornado.ioloopimport tornado.webimport tornado.genclass MainHandler(tornado.web.RequestHandler):async def get(self):await tornado.gen.sleep(2)self.write("Hello, 异步世界!")
def make_app():return tornado.web.Application([(r"/", MainHandler),])
if name == "main":app = make_app()app.listen(8888)print("服务运行在 https://www.php.cn/link/4f10ac32425eaa39b2f93cd9c67ff456")tornado.ioloop.IOLoop.current().start()
Tornado 更适合需要长时间保持连接的场景,比如实时聊天、推送服务等。
基本上就这些。asyncio 是现代 Python 异步的主流选择,而 Tornado 在特定场景下仍有优势,尤其是需要内置高性能服务器和 WebSocket 支持时。选择哪个取决于项目需求和生态依赖。不复杂但容易忽略的是:理解事件循环的运行机制,才能真正掌握这两种框架的使用。
以上就是python实现异步的两种框架的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1380603.html
微信扫一扫
支付宝扫一扫