位置: IT常识 - 正文

深究Python中的asyncio库-线程并发函数

编辑:rootadmin

推荐整理分享深究Python中的asyncio库-线程并发函数,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

Asyncio ——gather vs wait

在Asyncio中不止可以多次使用asyncio.gather,还有另外一个用法是asyncio.wait,他们都可以让多个协程并发执行。

那为什么提供2个方法呢?他们有什么区别,适用场景是怎么样的呢?我们先看2个协程的例子:

asyncdefa():print('Suspendinga')awaitasyncio.sleep(3)print('Resuminga')return'A'asyncdefb():print('Suspendingb')awaitasyncio.sleep(1)print('Resumingb')return'B'

在IPython里面用gather执行一下:

In:return_value_a,return_value_b=awaitasyncio.gather(a(),b())SuspendingaSuspendingbResumingbResumingaIn:return_value_a,return_value_bOut:('A','B')

Ok,asyncio.gather方法的名字说明了它的用途,gather的意思是「搜集」,也就是能够收集协程的结果,而且要注意,它会按输入协程的顺序保存的对应协程的执行结果。

接着我们说asyncio.await,先执行一下:

In:done,pending=awaitasyncio.wait([a(),b()])SuspendingbSuspendingaResumingbResumingaIn:doneOut:{<Taskfinishedcoro=<a()done,definedat<ipython-input-5-5ee142734d16>:1>result='A'>,<Taskfinishedcoro=<b()done,definedat<ipython-input-5-5ee142734d16>:8>result='B'>}In:pendingOut:set()In:task=list(done)[0]In:taskOut:<Taskfinishedcoro=<b()done,definedat<ipython-input-5-5ee142734d16>:8>result='B'>In:task.result()Out:'B'

asyncio.wait的返回值有2项,第一项表示完成的任务列表(done),第二项表示等待(Future)完成的任务列表(pending),每个任务都是一个Task实例,由于这2个任务都已经完成,所以可以执行task.result()获得协程返回值。

Ok, 说到这里,总结下它俩的区别的第一层区别:

asyncio.gather封装的Task全程黑盒,只告诉你协程结果。

深究Python中的asyncio库-线程并发函数

asyncio.wait会返回封装的Task(包含已完成和挂起的任务),如果你关注协程执行结果你需要从对应Task实例里面用result方法自己拿。

为什么说「第一层区别」,asyncio.wait看名字可以理解为「等待」,所以返回值的第二项是pending列表,但是看上面的例子,pending是空集合,那么在什么情况下,pending里面不为空呢?这就是第二层区别:asyncio.wait支持选择返回的时机。

asyncio.wait支持一个接收参数return_when,在默认情况下,asyncio.wait会等待全部任务完成(return_when='ALL_COMPLETED'),它还支持FIRST_COMPLETED(第一个协程完成就返回)和FIRST_EXCEPTION(出现第一个异常就返回):

In:done,pending=awaitasyncio.wait([a(),b()],return_when=asyncio.tasks.FIRST_COMPLETED)SuspendingaSuspendingbResumingbIn:doneOut:{<Taskfinishedcoro=<b()done,definedat<ipython-input-5-5ee142734d16>:8>result='B'>}In:pendingOut:{<Taskpendingcoro=<a()runningat<ipython-input-5-5ee142734d16>:3>wait_for=<Futurependingcb=[<TaskWakeupMethWrapperobjectat0x108065e58>()]>>}

看到了吧,这次只有协程b完成了,协程a还是pending状态。

在大部分情况下,用asyncio.gather是足够的,如果你有特殊需求,可以选择asyncio.wait,举2个例子:

需要拿到封装好的Task,以便取消或者添加成功回调等

业务上需要FIRST_COMPLETED/FIRST_EXCEPTION即返回的

asyncio.create_task vs loop.create_task vs asyncio.ensure_future

创建一个Task一共有3种方法,如这小节的标题。在上篇文章我说过,从Python 3.7开始可以统一的使用更高阶的asyncio.create_task。其实asyncio.create_task就是用的loop.create_task:

defcreate_task(coro):loop=events.get_running_loop()returnloop.create_task(coro)

loop.create_task接受的参数需要是一个协程,但是asyncio.ensure_future除了接受协程,还可以是Future对象或者awaitable对象:

如果参数是协程,其实底层还是用的loop.create_task,返回Task对象

如果是Future对象会直接返回

如果是一个awaitable对象会await这个对象的__await__方法,再执行一次ensure_future,最后返回Task或者Future

所以就像ensure_future名字说的,确保这个是一个Future对象:Task是Future 子类,前面说过一般情况下开发者不需要自己创建Future

其实前面说的asyncio.wait和asyncio.gather里面都用了asyncio.ensure_future。对于绝大多数场景要并发执行的是协程,所以直接用asyncio.create_task就足够了~

本文链接地址:https://www.jiuchutong.com/zhishi/304550.html 转载请保留说明!

上一篇:泛化之美 —— C++11 可变参数模板的妙用(泛化的理解)

下一篇:In Java, how do I read/convert an InputStream to a String? Stack Overflow

  • 三星手机usb调试在哪里打开(三星手机USB调试功能在哪里)

    三星手机usb调试在哪里打开(三星手机USB调试功能在哪里)

  • 苹果教育优惠必须本人签收吗(苹果教育优惠必须是在读大学生吗)

    苹果教育优惠必须本人签收吗(苹果教育优惠必须是在读大学生吗)

  • 淘宝怎么加入阿里爱心助农平台(淘宝怎么加入阿里客服)

    淘宝怎么加入阿里爱心助农平台(淘宝怎么加入阿里客服)

  • 微信号改不了条件未满足(微信号改不了条码怎么办)

    微信号改不了条件未满足(微信号改不了条码怎么办)

  • 支付宝怎么绑定身份证(支付宝怎么绑定店员到账通知)

    支付宝怎么绑定身份证(支付宝怎么绑定店员到账通知)

  • h61和b75有什么不一样(h61还是b75)

    h61和b75有什么不一样(h61还是b75)

  • 编码器的作用(旋转编码器的作用)

    编码器的作用(旋转编码器的作用)

  • 移动硬盘接口类型(移动硬盘接口类型有哪些)

    移动硬盘接口类型(移动硬盘接口类型有哪些)

  • 华为手机怎么设置颜色反转(华为手机怎么设置下面的三个功能键)

    华为手机怎么设置颜色反转(华为手机怎么设置下面的三个功能键)

  • 对讲机充电要多久(对讲机充电多少伏)

    对讲机充电要多久(对讲机充电多少伏)

  • word文档怎么画线条(word文档怎么画下划线横线)

    word文档怎么画线条(word文档怎么画下划线横线)

  • 快手极速版是什么东西(快手极速版是什么系)

    快手极速版是什么东西(快手极速版是什么系)

  • 苹果备忘录怎么设置提醒(苹果备忘录怎么设置密码锁)

    苹果备忘录怎么设置提醒(苹果备忘录怎么设置密码锁)

  • 手机qq分屏怎么设置(手机qq分屏怎么关闭)

    手机qq分屏怎么设置(手机qq分屏怎么关闭)

  • 努比亚红魔3s什么时候上市(努比亚 红魔3s)

    努比亚红魔3s什么时候上市(努比亚 红魔3s)

  • 荣耀20的指纹解锁在哪(荣耀20指纹解锁坏了)

    荣耀20的指纹解锁在哪(荣耀20指纹解锁坏了)

  • 闲鱼如何防止骗子买家(闲鱼购物如何防骗)

    闲鱼如何防止骗子买家(闲鱼购物如何防骗)

  • 云美摄怎么编辑视频(云美摄视频制作教程云美摄)

    云美摄怎么编辑视频(云美摄视频制作教程云美摄)

  • ppt工具栏隐藏后如何恢复(ppt工具栏隐藏后如何调出来)

    ppt工具栏隐藏后如何恢复(ppt工具栏隐藏后如何调出来)

  • 苹果手机怎么取消预订的app(苹果手机怎么取消静音模式)

    苹果手机怎么取消预订的app(苹果手机怎么取消静音模式)

  • 天翼看家支持5部终端么(天翼看家支持5G吗)

    天翼看家支持5部终端么(天翼看家支持5G吗)

  • 群聊的聊天记录怎么转发(群聊的聊天记录删了怎么恢复)

    群聊的聊天记录怎么转发(群聊的聊天记录删了怎么恢复)

  • 淘宝如何查物流(淘宝如何查物流信息查询)

    淘宝如何查物流(淘宝如何查物流信息查询)

  • 增加织梦模板DEDECMS会员签到功能的源码教程(织梦怎么用)

    增加织梦模板DEDECMS会员签到功能的源码教程(织梦怎么用)

  • js如何创建执行上下文(js怎么执行函数)

    js如何创建执行上下文(js怎么执行函数)

  • 小规模纳税人征税规定
  • 金银首饰以旧换新增值税
  • 多缴税款抵税有期限吗
  • 一般纳税人企业所得税税率
  • 抬头 个人
  • 商业企业的商品销售额、职工人数是( )
  • 商业汇票贴现金额的计算
  • 结转上年度的企业所得税会计分录?
  • 所得税汇算清缴报告在哪查
  • 企业接受基金投资的规定
  • 递延所得税资产是什么
  • 在杂志上发表论文
  • 慈善会可以开什么票据
  • 没有三方协议怎么缴纳社保
  • 物业管理的差额怎么算
  • 营业外收入怎么申报
  • 营业收入大于营业成本居然亏损
  • 建筑劳务公司的会计账务处理
  • 为什么Win7电脑开机时会卡在
  • 为什么叫win7
  • 任务栏变宽了怎么调回来win11
  • win10excel闪退是什么原因
  • 代理公司变更收费标准
  • win10 累积更新
  • win11预览版dev改beta
  • 魅族路由器mini padavan
  • 资产减值准则所规范的资产
  • 傅里叶级数狄利克雷判别法
  • python web开发方向的第三方库有哪些
  • 我的年终总结怎么写
  • 增值税报税后多久缴纳期限
  • 民办非企业现金流量表的编制公式
  • python np数组
  • sqlserver使用awe分配内存
  • python多线程多核
  • 进项与销项区别
  • 汇总记账凭证账务处理
  • 个税返还手续费政策
  • 每月工资不一样怎么算误工费呢
  • 小规模纳税人销售不动产适用税率
  • 印花税征税对象是什么
  • 年终奖都有啥
  • 损益类会计科目有哪些
  • 计提社保公积金的账务处理
  • 免增值税进项税怎么弄
  • 劳保统筹费缴费比例
  • 加油站汽油损耗分析
  • 实报实销有补贴嘛
  • 公司开具电子发票是否取消纸质发票开具
  • 汽车4s店有哪些功能
  • 车辆保险证明怎么开
  • 会计里面权益是什么
  • 发票专用章需要备案吗?
  • 成本会计主要做什么工作
  • 税务登记证办理流程
  • 总分类账建账顺序
  • 阿里云linux 服务器 字符集
  • samba webui
  • 七喜r11c笔记本
  • WIN10系统中没有接入音频设备 要启动gui
  • windows8快速启动设置
  • win8系统硬盘怎样分区
  • Win10 Mobile 10586.312提前体验
  • bootstrap 图表插件
  • jquery table加载数据
  • net命令用法
  • perl语言
  • Node.js中的construct
  • Node.js中的事件循环是什么意思
  • linux随机数生成1到100
  • JavaScript中void(0)的具体含义解释
  • Android mediaplayer 白屏
  • 有哪些比较好的android的框架
  • androidstudio快速入门
  • 重大税务违法案件一案双查标准
  • 消费税的征收范围口诀
  • 西安税务办税服务厅
  • 电子税务局帐号不知道怎么找
  • 开票软件里的统计怎么弄
  • 增值税纳税申报表附列资料(三)
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设