python 的异步框架模型
python提供了asyncio模块来支持异步编程,其中涉及到coroutines、eventloops、futures三个重要概念;
eventloops主要负责跟踪和调度所有异步任务,编排具体的某个时间点执行的任务;
coroutines是对具体执行任务的封装,是一个可以在执行中暂停并切换到eventloops执行流程的特殊类型的函数;其一般还需要创建task才能被eventloops调度;
futures负责承载coroutines的执行结果,其随着任务在eventloops中的初始化而创建,并随着任务的执行来记录任务的执行状态;
异步编程框架的整个执行过程涉及三者的紧密协作;
首先eventloops启动之后,会从任务队列获取第一个要执行的coroutine,并随之创建对应task和future;
然后随着task的执行,当遇到coroutine内部需要切换任务的地方,task的执行就会暂停并释放执行线程给eventloop,eventloop接着会获取下一个待执行的coroutine,并进行相关的初始化之后,执行这个task;
随着eventloop执行完队列中的最后一个coroutine才会切换到第一个coroutine;
随着task的执行结束,eventloops会将task清除出队列,对应的执行结果会同步到future中,这个过程会持续到所有的task执行结束;
以上内容为大家介绍了python的异步框架模型,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:开发教育。http://www.baikegou.com/
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!