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

  • 手机查银行卡余额怎么查(手机查银行卡余额密码输入错误三次怎么办)

    手机查银行卡余额怎么查(手机查银行卡余额密码输入错误三次怎么办)

  • 2021美团怎么看自己的评论(美团在哪里查看)

    2021美团怎么看自己的评论(美团在哪里查看)

  • 为什么抖音作品没人浏览(为什么抖音作品一直在审核)

    为什么抖音作品没人浏览(为什么抖音作品一直在审核)

  • 卖家线下换新什么意思(线下换货)

    卖家线下换新什么意思(线下换货)

  • 全民k歌怎么不让qq好友看到(全民k歌怎么不让某个人看到)

    全民k歌怎么不让qq好友看到(全民k歌怎么不让某个人看到)

  • 停机后充话费能恢复吗(停机后充话费能恢复短信吗)

    停机后充话费能恢复吗(停机后充话费能恢复短信吗)

  • wan口一直连接不上(wan口连接失败怎么回事)

    wan口一直连接不上(wan口连接失败怎么回事)

  • 无人机系统包括哪五个系统(无人机系统包括无人机什么什么什么和综合保障系统)

    无人机系统包括哪五个系统(无人机系统包括无人机什么什么什么和综合保障系统)

  • excel主要应用在什么方面(excel的应用场景有哪些)

    excel主要应用在什么方面(excel的应用场景有哪些)

  • 支付宝扣费设置在哪里(支付宝扣费设置在哪里关闭)

    支付宝扣费设置在哪里(支付宝扣费设置在哪里关闭)

  • 闹钟上的on和off是什么意思(闹钟里on和off是什么意思)

    闹钟上的on和off是什么意思(闹钟里on和off是什么意思)

  • 快手删除了可以恢复吗(删除快手还能找回吗)

    快手删除了可以恢复吗(删除快手还能找回吗)

  • word文档怎么写下一行(word文档怎么写分式)

    word文档怎么写下一行(word文档怎么写分式)

  • word2000是应用软件吗(word2003是应用软件)

    word2000是应用软件吗(word2003是应用软件)

  • vivo怎么唤醒小v(vivo怎么唤醒小冰)

    vivo怎么唤醒小v(vivo怎么唤醒小冰)

  • qq里解除关系是什么意思(qq解除关系有提示吗)

    qq里解除关系是什么意思(qq解除关系有提示吗)

  • 快手点赞红心上限是多少(快手点红心有什么用处)

    快手点赞红心上限是多少(快手点红心有什么用处)

  • 苹果6plus支持快充吗(苹果6p支持快充)

    苹果6plus支持快充吗(苹果6p支持快充)

  • 华为Eyewear是什么材质(华为eyewear2)

    华为Eyewear是什么材质(华为eyewear2)

  • 电脑网络连接感叹号(电脑网络连接感叹号怎么办)

    电脑网络连接感叹号(电脑网络连接感叹号怎么办)

  • 小米cc9可以升级MIUI11吗(小米cc9可以升级系统吗)

    小米cc9可以升级MIUI11吗(小米cc9可以升级系统吗)

  • airpods刻了字还能退吗(airpods刻了字还能退货吗)

    airpods刻了字还能退吗(airpods刻了字还能退货吗)

  • 如何修改路由器密码(如何修改路由器设置)

    如何修改路由器密码(如何修改路由器设置)

  • 极速版抖音怎么拍视频(极速版抖音怎么提现到支付宝)

    极速版抖音怎么拍视频(极速版抖音怎么提现到支付宝)

  • iphonexr可以用ipad充电器充电吗(iphonexr能用iphone12的手机壳吗)

    iphonexr可以用ipad充电器充电吗(iphonexr能用iphone12的手机壳吗)

  • 苹果8p打电话声音小怎么回事(苹果8p打电话声音小怎么调)

    苹果8p打电话声音小怎么回事(苹果8p打电话声音小怎么调)

  • iphonexr有没有nfc(iphonexrnfc在哪个位置)

    iphonexr有没有nfc(iphonexrnfc在哪个位置)

  • 106905695559什么交通短信(1069095959是什么号码)

    106905695559什么交通短信(1069095959是什么号码)

  • dns解析过程(简述dns解析过程)

    dns解析过程(简述dns解析过程)

  • 魁北克老城区的景色,加拿大 (© RENAULT Philippe/age fotostock)(魁北克老城区景点)

    魁北克老城区的景色,加拿大 (© RENAULT Philippe/age fotostock)(魁北克老城区景点)

  • 支付国外佣金代扣代缴增值税
  • 旧设备出口增值税处理
  • 车辆计提折旧需要计提吗
  • 公司会计日常工作内容
  • 零余额账户出纳做什么
  • 小微企业注册流程及费用微
  • 劳务费属于印花税范围吗
  • 收据能入账抵税吗
  • 银行开户许可证图片
  • 用于职工住宿的会计科目
  • 高速路费电子发票怎么打印
  • 短期借款的会计凭证
  • 月末应付职工薪酬计算方法
  • 仓库的数量为负数怎么办
  • 公司向个人借款利率最高多少
  • 停车场增加收入
  • 发票验旧后可领新发票吗
  • 长期待摊费用当月减少当月摊销吗
  • 长期待摊费用原值怎么填
  • 公司买的固定资产还没使用
  • 企业汽油费会计分录
  • 期末留抵税额可以冲减欠税吗
  • linux的使用场合
  • 税收是财政政策传导机制中重要的媒介之一
  • 增值税出口退税为什么不属于政府补助
  • 默认网关不可用的解决办法
  • 酒店没有营业执照开业员工有责任吗
  • 出租固定资产取得的净收益计入什么科目
  • mssvr.exe - mssvr是什么进程 什么用
  • php类和对象
  • phpeach函数
  • 销售收入与销售成本
  • 制造企业成本计算模型有哪些类型
  • 金融行业如何征收营业税
  • php md5加盐
  • 什么情况下增长率是0
  • 董事费如何计算个人所得税
  • 广告代理费收取比例
  • php 字符串处理函数
  • 关于商业承兑汇票的多选题有哪些
  • 使用spring框架,大概有哪些步骤
  • 智慧工厂协同管控下载
  • 固定资产的原价包括增值税吗
  • 资产处置损益是什么类
  • phpcms官网打不开
  • 前端培训费用大概多少
  • 国家定额发票使用范围
  • 蔬菜和肉类是不是免税
  • 环境检测收费依据2017
  • 股东投钱一般怎么投
  • 资产管理业务是表外业务吗
  • db2数据库管理的工具
  • 支付宝收付款如何截图
  • 购买产品样品计入什么科目
  • 非居民企业所得税
  • 土地需要摊销嘛?
  • 投资性房地产递延所得税其他综合收益
  • 服务器托管税率
  • 工厂的委托加工怎么写
  • win7哪年停止更新
  • win7怎么下载win10
  • centos怎么调出终端
  • win7更改电脑设置在哪里
  • centos查看某个端口
  • dsapi.exe是什么
  • win7如何删除网络上的其它计算机
  • linux磁盘的使用方式
  • xp系统无法正常启动怎么办
  • win系统开发
  • pax是什么文件
  • WIN10系统中WPS字体颜色浅
  • windows 10预览版
  • opengl cullface
  • cocos2dx官方教程
  • document.getElementByTagName
  • 基于nodejs的项目
  • 衬线字体和无衬线字体各自的用途
  • js对象用法
  • 快速解决偏头痛的6个方法
  • 税源管理科是干什么的
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设