位置: 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

  • 支付宝最近转账人员怎么删除(支付宝最近转账银行卡怎么删除)

    支付宝最近转账人员怎么删除(支付宝最近转账银行卡怎么删除)

  • word怎么把附件分离出来(word怎么把附件1分离出来)

    word怎么把附件分离出来(word怎么把附件1分离出来)

  • 一个微信可以申请几个健康码(一个微信可以申请几个公众号)

    一个微信可以申请几个健康码(一个微信可以申请几个公众号)

  • vivo前置摄像头打不开(vivo前置摄像头打开失败是怎么回事)

    vivo前置摄像头打不开(vivo前置摄像头打开失败是怎么回事)

  • 抖音小店5000押金可以退吗(抖音小店5000押金在手机上可以退)

    抖音小店5000押金可以退吗(抖音小店5000押金在手机上可以退)

  • 微信地址中国大陆怎么设置(微信地址中国大陆怎么设置上去呢)

    微信地址中国大陆怎么设置(微信地址中国大陆怎么设置上去呢)

  • 三星note3上市日期(三星note3首发价)

    三星note3上市日期(三星note3首发价)

  • 华为手机软件闪退怎么办(华为手机助手(安卓版)最新手机版)

    华为手机软件闪退怎么办(华为手机助手(安卓版)最新手机版)

  • 苹果手机怎么提升4g网速(苹果手机怎么提高音量)

    苹果手机怎么提升4g网速(苹果手机怎么提高音量)

  • 搜狗浏览器截图快捷键(搜狗浏览器截图快捷键怎么设置)

    搜狗浏览器截图快捷键(搜狗浏览器截图快捷键怎么设置)

  • 进朋友圈会留下记录吗(进朋友圈会被发现吗)

    进朋友圈会留下记录吗(进朋友圈会被发现吗)

  • 计算机中操作系统是什么的接口(计算机中操作系统的分类)

    计算机中操作系统是什么的接口(计算机中操作系统的分类)

  • 相机cmos是什么(相机cmos是什么进灰)

    相机cmos是什么(相机cmos是什么进灰)

  • ps怎么修人脸(ps怎么修人脸瑕疵)

    ps怎么修人脸(ps怎么修人脸瑕疵)

  • 为什么手机页面上会出现HD(为什么手机页面频繁出来小广告?)

    为什么手机页面上会出现HD(为什么手机页面频繁出来小广告?)

  • 如何用手机做尺子测量(怎么用手机做尺子)

    如何用手机做尺子测量(怎么用手机做尺子)

  • 小米手机网速慢怎么调(小米手机网速慢怎么设置)

    小米手机网速慢怎么调(小米手机网速慢怎么设置)

  • 腾讯地图怎么添加店铺(腾讯地图怎么添加新店铺)

    腾讯地图怎么添加店铺(腾讯地图怎么添加新店铺)

  • 华为nova5pro多少w快充(华为nova5pro多少毫安)

    华为nova5pro多少w快充(华为nova5pro多少毫安)

  • 苹果11背面有字母吗(苹果11背面有字母什么意思)

    苹果11背面有字母吗(苹果11背面有字母什么意思)

  • p40什么时候上市的(红米p40什么时候上市)

    p40什么时候上市的(红米p40什么时候上市)

  • 荣耀9x充满电要多久(荣耀9x充电时间多久)

    荣耀9x充满电要多久(荣耀9x充电时间多久)

  • 苹果刷脸刷不了怎么办(苹果的刷脸功能怎么刷不出来)

    苹果刷脸刷不了怎么办(苹果的刷脸功能怎么刷不出来)

  • airpods二代安卓手机可以用吗(airpods二代安卓怎么连接)

    airpods二代安卓手机可以用吗(airpods二代安卓怎么连接)

  • 王者荣耀本地回放怎么保存到手机(王者荣耀本地回放多久过期)

    王者荣耀本地回放怎么保存到手机(王者荣耀本地回放多久过期)

  • 小米8后盖怎么拆(小米8后盖怎么装回去)

    小米8后盖怎么拆(小米8后盖怎么装回去)

  • 设计印刷合同
  • 拟上市企业需要做什么
  • 企业所得税怎么算出来
  • 票种核定表怎么填写
  • 发票金额太大怎么拆分数量,单价不变还是数量不变
  • 运输企业支付罚款如何账务处理
  • 土地政策补贴
  • 提取备用金如何在退回公司
  • 专项土地补偿款怎么入账?
  • 营改增后在建工程转让应缴纳税费有哪些
  • 集团内关联企业有哪些
  • 开具增值税专用发票怎么开
  • 小规模纳税人可以开9%专票吗
  • 异地不动产租赁 深圳税务 所得税
  • 取得甲供材料按简易征收发票能抵扣吗
  • 股东折价入股会计分录
  • 进项税大于销项税是不是不用交税了
  • 购车保险属于什么费用
  • 设定受益计划资产上限
  • 金税盘开红字发票
  • 工资是一定是月薪吗
  • 企业享受小型微利政策
  • 冲上年收入会计分录
  • 机关党建经费提取比例
  • msiexec.exe是什么进程介绍
  • 商事账薄的特征
  • 写一段简单的自我介绍
  • 生产企业委外加工比例出口免抵退税
  • linux用不了yum
  • bassmod.dll
  • phpswoole面试
  • PHP:imagecreatefromwebp()的用法_GD库图像处理函数
  • iis制作网页
  • php数组操作函数
  • php面向对象是什么意思
  • php支付宝支付流程原理
  • 华为od机试无法测用例
  • php安装教程
  • 微软官方wintogo
  • 小规模纳税人增值税月末处理
  • 支付价款含不含增值税
  • python中sys模块
  • 购买方红字信息表已开销售方系统查不到
  • 会计人员信息采集怎么看审核通过
  • mysql深入理解
  • 企业所得税汇算清缴表
  • 合并报表抵消分录
  • 账龄划分中有借有贷怎么分析
  • 结转上年
  • 增值税及附加税费申报表附列资料一
  • 一般纳税人增值税减免政策2023
  • 定期定额户超过9万如何交个税
  • 银行存款利息如何计算
  • 房地产行业扣税标准
  • 帮别人加工需要什么手续
  • 支付给劳务人员劳务费需缴纳印花
  • 商业承兑背书后怎么办
  • 外贸内销业务哪个部门管
  • 苗木补偿款
  • 小企业会计准则以前年度损益调整
  • ubuntu14.04安装vim
  • windows10周年纪念版
  • ubuntu-desktop启动
  • mac打印预览快捷键是什么
  • windows有两个
  • linux中ls命令的功能
  • win7的系统设置
  • win8.1系统更新
  • linux如何使用u盘
  • [置顶]电影名字《收件人不详》
  • perl \w
  • vue.js如何使用
  • python如何发送http请求
  • Python中使用装饰器来优化尾递归的示例
  • 2006年发生哪一些大案
  • 收到补税点的分录
  • 政府采购合同模板
  • PLC交通信号灯控制程序设计
  • 国税增值税申报怎么记账凭证填写
  • 上海市办居住证流程
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设