异步函数与异步生成器

异步函数介绍

定义:使用 async def 关键字定义的函数,可以暂停执行并在稍后恢复

特点:函数内部可以使用 await 关键字等待其他异步操作完成

返回值:调用时返回协程对象(coroutine),而不是直接执行函数体

性能方面:

  • I/O 密集型:异步并发优势明显
  • CPU 密集型:对于计算密集型任务,异步并不能带来性能提升

其它:避免在异步函数中使用阻塞操作,如 time.sleep(),使用异步版本的操作,如 await asyncio.sleep()

定义

复制代码
async def function_name(parameters):
    # 异步函数体
    await some_async_operation()
    return result

定义要点

  • 使用 async def 替代普通函数的 def
  • 函数内部可以使用 await 关键字
  • 可以使用 return 返回值

调用

在异步环境中调用

  • 使用 await:在另一个异步函数中使用 await function_name()
  • 返回协程对象:直接调用 function_name() 返回协程对象

在同步环境中调用

  • 使用 asyncio.run():asyncio.run(function_name())
  • 创建事件循环:手动创建和管理事件循环

示例

同步环境中调用:asyncio.run

示例:

复制代码
async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


res = hello()
print(res, type(res))

输出结果

复制代码
<coroutine object hello at 0x0000023CA3CA5B40> <class 'coroutine'>
<sys>:0: RuntimeWarning: coroutine 'hello' was never awaited

上面直接调用异步函数hello()会返回一个协程对象,而不是执行函数

修改:asyncio.run()是运行异步函数的标准方式

复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


res = hello()
print(res, type(res))
res2 = asyncio.run(res)
print(res2, type(res2))

输出结果:

复制代码
<coroutine object hello at 0x00000216F8162680> <class 'coroutine'>
全栈测试笔记
qzcsbj <class 'str'>

优化

复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


if __name__ == "__main__":
    res = hello()
    print(res, type(res))
    res2 = asyncio.run(res)
    print(res2, type(res2))

执行流程:

  • asyncio.run(hello()) 直接启动事件循环
  • 直接执行 hello() 函数并返回结果
  • 简洁的单函数执行模
异步环境中调用:await
复制代码
import asyncio


async def hello():
    print("全栈测试笔记")
    return "qzcsbj"


async def call_hello():
    res = hello()
    print(res, type(res))
    res2 = await res  # await res等价于await hello()
    print(res2, type(res2))


if __name__ == "__main__":
    # call_hello()  # 报错:coroutine 'call_hello' was never awaited call_hello()
    asyncio.run(call_hello())

输出结果:

复制代码
<coroutine object hello at 0x0000023816222680> <class 'coroutine'>
全栈测试笔记
qzcsbj <class 'str'>

执行流程:

  • asyncio.run(call_hello()) 启动事件循环
  • call_hello() 内部先获取 hello() 的协程对象
  • 通过 await 等待协程执行完成
  • 演示了协程对象的创建和等待过程

异步生成器

参考:https://www.cnblogs.com/uncleyong/p/6208547.html

相关推荐
狂炫冰美式5 分钟前
人均配了AI, 为什么公司还是没变快? 🤔 本质还是分布式系统问题
前端·后端·架构
乘风gg1 小时前
多 Agent 不是万能的!搞懂这 5 个原则,少走 1 年弯路!
前端·agent·ai编程
猩猩程序员2 小时前
Vercel 推出 Agent 框架 Eve:让 AI Agent 像写 Web 应用一样简单
前端
ClouGence2 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
爱读源码的大都督2 小时前
Claude Code源码分析(三):为什么系统提示词中需要有tools呢?
前端·人工智能·后端
爱勇宝2 小时前
Claude Code 被曝暗藏“隐形检测”代码:封代理不是最可怕的,可怕的是你根本不知道它在干什么
前端·后端·程序员
小牛不牛的程序员2 小时前
我用 Claude Code 半天撸完了一个完整网站,AI 编程到底提升了多少效率?
前端
东风破_2 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
ITOM运维行者3 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
monologues3 小时前
深入 Vue 3 源码:响应式系统的精妙设计与编译优化
前端