异步函数与异步生成器

异步函数介绍

定义:使用 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

相关推荐
Lee_SmallNorth2 小时前
变态需求之【角色不同访问数据库的用户不同】
java·开发语言·数据库
李慕婉学姐2 小时前
Springboot连锁火锅管理及预测系统sh5s1gn1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
weixin_462446232 小时前
Linux 下使用 xfreerdp3 远程连接 Windows(从安装到实战使用)
linux·运维·windows
木头左2 小时前
基于Backtrader框架的指数期权备兑策略实现与分析
python
dishugj2 小时前
【oracle】19c集群巡检问题
数据库·oracle
知识分享小能手2 小时前
Oracle 19c入门学习教程,从入门到精通,Oracle 其他数据对象 —— 语法详解与综合实践(11)
数据库·学习·oracle
EndingCoder2 小时前
配置 tsconfig.json:高级选项
linux·前端·ubuntu·typescript·json
木风小助理2 小时前
JavaStreamAPI的性能审视,优雅语法背后的隐形成本与优化实践
java·前端·数据库
爱丶狸2 小时前
Linux三剑客之sed
linux·运维·服务器