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

  • 出口退税免税有限额吗
  • 个体户转一般纳税人怎么做账
  • 开票地址太长显示不全
  • 劳务公司开票税收分类
  • 本月进项税大于销项税有留底,如何做会计分录
  • 公司现金支票取现用途怎么填写
  • 报销油费如何写摘要及会计分录怎么做?
  • 将自产产品用于投资
  • 让渡资产使用权是指资产的所有者将
  • 佣金可以直接转到个人账户吗
  • 营改增后房地产企业增值税如何核算
  • 开办期间的税控设备怎么入账?
  • 入职不满一年有年假吗
  • 服务型企业管理体系
  • 自收自支事业单位
  • 集团公司内部无偿借贷增值税
  • 稿酬所得的个税计算
  • 建筑业简易计税进项税可以抵扣吗
  • 企业采购成本包括所有的仓储费用
  • 商品超出几倍合法
  • 购买土地交易费用怎么算
  • 支付工会经费
  • 经营出租固定资产折旧额计入什么科目
  • 磁盘碎片指的是磁盘因为长期使用
  • wordpress主题0skr
  • SchSvr.exe - SchSvr是什么进程 有什么作用
  • 微信小程序完美修真攻略
  • 工业企业缴纳的税费种类包括
  • 广告费和业务宣传费税前扣除基数
  • 房地产企业借款可以用未建成的房子设定浮动抵押吗?
  • php数组按照某个字段排序
  • phpmyadmin无法登陆mysql数据库
  • 企业所得税的计提和缴纳分录
  • 蓝桥杯b组2020
  • sockas
  • semeion手写数据集
  • php禁用函数怎么删除
  • php中url什么意思
  • 逾期的押金税率是多少
  • 个人应纳所得税计算公式
  • 退货的会计处理分录
  • 收入少收钱账务处理
  • python poetry如何创建项目
  • 投资款印花税税源采集表税目
  • 新会计准则下的资产负债表
  • 合同取得成本的账务处理
  • mysql更新语句
  • 建筑企业分项目信息采集表怎么填
  • 在建工程账务怎么会转到预收账款
  • 人工费暂估怎么做分录
  • 代理服务费如何缴纳
  • 发票普通发票
  • 持有至到期投资减值准备可以转回吗
  • 三证合一办理流程及费用
  • 航天信息全额抵扣分录
  • 商业医疗保险的缺点
  • 工会需要独立建账吗
  • 营改增后建筑企业如何正确开具发票
  • 二类银行卡是什么卡
  • 会计凭证销毁的地方
  • vmware安装redhat6.5
  • fedora vlc
  • solaris 11.4
  • ami 2.17.1254bios设置图解教程
  • win7系统调亮度怎么调
  • 如何用u盘安装win8操作系统
  • 家用电脑是什么机型
  • extend列表
  • jquery自定义
  • jQuery的ajax中使用FormData实现页面无刷新上传功能
  • android实战项目
  • jq点击图片让图片进行切换
  • javascript 进阶篇1 正则表达式,cookie管理,userData
  • jQuery基本选择器
  • 查验发票真伪
  • 国家税务局何时上班
  • 厂房原值如何核定
  • 苏州地方税务
  • 船舶吨税是中央税还是地方税
  • 宣传中常用的效应包括
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设