python实现异步编程主要依靠asyncio模块,其核心在于理解事件循环、协程和async/await语法。1.asyncio是python标准库中用于编写异步代码的核心工具,通过事件循环调度协程,使程序在等待i/o操作时不阻塞主线程。2.异步函数用async def定义,内部使用await等待其他异步操作完成,从而实现非阻塞并发。3.asyncio.run()是启动异步主函数的推荐方式,它自动创建并关闭事件循环。4.要并发运行多个任务,可以使用asyncio.create_task()或asyncio.gather(),它们允许同时执行多个异步任务并等待全部完成。5.常见误区包括:只能await协程对象、避免使用阻塞函数如time.sleep()、以及asyncio不适合cpu密集型任务。掌握这些关键点有助于快速理解并应用异步编程。

Python 实现异步编程主要靠 asyncio 模块,它是 Python 标准库中用于编写异步代码的核心工具。如果你之前写过同步代码,可能会觉得异步有点绕,但其实只要理解几个关键点,就能快速上手。

什么是异步编程?
简单来说,异步编程就是让程序在等待某个操作完成时,不卡住、不空等,而是去做别的事情。比如网络请求、文件读写、数据库查询这些耗时操作,如果用传统的同步方式处理,程序会一直等着,效率低。而异步可以让多个任务“并发”执行,提升整体性能。
async 和 await 是什么?
在 Python 中,异步函数用 async def 定义,里面可以通过 await 等待其他异步函数的执行结果。这有点像你点了外卖之后不干等,而是继续刷视频,等外卖到了再暂停视频去取餐。
立即学习“Python免费学习笔记(深入)”;

举个例子:
import asyncioasync def say_hello(): print("Hello") await asyncio.sleep(1) print("World")asyncio.run(say_hello())
这个例子中,say_hello 是一个异步函数,里面用 await 等待 asyncio.sleep(1) 完成。执行时,程序不会卡住,而是可以处理其他任务(虽然这个例子中只有一个任务)。

asyncio.run 是做什么的?
asyncio.run() 是 Python 3.7 引入的一个非常方便的函数,用来启动一个异步主函数。你可以把它理解为异步程序的入口。它会自动创建事件循环,并在执行完后关闭它。
如果你之前用过 loop = asyncio.get_event_loop() 和 loop.run_until_complete(),那 asyncio.run() 就是它们的简化版,推荐新手直接使用它。
如何并发运行多个任务?
想让多个异步任务同时运行?可以用 asyncio.create_task() 或 asyncio.gather()。
举个例子:
async def task1(): print("Task 1 started") await asyncio.sleep(2) print("Task 1 done")async def task2(): print("Task 2 started") await asyncio.sleep(1) print("Task 2 done")async def main(): t1 = asyncio.create_task(task1()) t2 = asyncio.create_task(task2()) await t1 await t2asyncio.run(main())
这里我们创建了两个任务,并发执行。你会发现 Task 2 虽然比 Task 1 先完成,但整个程序不会提前结束,因为 await t1 和 await t2 会等待它们全部完成。
你也可以用 await asyncio.gather(t1, t2) 来代替两次 await,效果一样。
常见误区和注意事项
不是所有函数都能 await:只能 await 另一个 async def 函数或返回协程对象的东西。阻塞函数要小心:比如 time.sleep() 会阻塞整个线程,应该用 asyncio.sleep() 替代。CPU 密集型任务不适合用 asyncio:因为 Python 的 GIL 存在,异步更适合 I/O 密集型任务。
基本上就这些。asyncio 的核心概念不多,但刚接触时容易被事件循环、协程这些概念绕进去。只要多写几个例子,理解 async def、await 和 asyncio.run() 的作用,就能慢慢掌握异步编程的思路了。
以上就是Python如何实现异步编程?asyncio入门的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1364607.html
微信扫一扫
支付宝扫一扫