python提供了asyncio模塊來支持異步編程,其中涉及到coroutines、eventloops、futures三個(gè)重要概念;
eventloops主要負(fù)責(zé)跟蹤和調(diào)度所有異步任務(wù),編排具體的某個(gè)時(shí)間點(diǎn)執(zhí)行的任務(wù);
coroutines是對(duì)具體執(zhí)行任務(wù)的封裝,是一個(gè)可以在執(zhí)行中暫停并切換到eventloops執(zhí)行流程的特殊類型的函數(shù);其一般還需要?jiǎng)?chuàng)建task才能被eventloops調(diào)度;
futures負(fù)責(zé)承載coroutines的執(zhí)行結(jié)果,其隨著任務(wù)在eventloops中的初始化而創(chuàng)建,并隨著任務(wù)的執(zhí)行來記錄任務(wù)的執(zhí)行狀態(tài);
異步編程框架的整個(gè)執(zhí)行過程涉及三者的緊密協(xié)作;
首先eventloops啟動(dòng)之后,會(huì)從任務(wù)隊(duì)列獲取第一個(gè)要執(zhí)行的coroutine,并隨之創(chuàng)建對(duì)應(yīng)task和future;
然后隨著task的執(zhí)行,當(dāng)遇到coroutine內(nèi)部需要切換任務(wù)的地方,task的執(zhí)行就會(huì)暫停并釋放執(zhí)行線程給eventloop,eventloop接著會(huì)獲取下一個(gè)待執(zhí)行的coroutine,并進(jìn)行相關(guān)的初始化之后,執(zhí)行這個(gè)task;
隨著eventloop執(zhí)行完隊(duì)列中的最后一個(gè)coroutine才會(huì)切換到第一個(gè)coroutine;
隨著task的執(zhí)行結(jié)束,eventloops會(huì)將task清除出隊(duì)列,對(duì)應(yīng)的執(zhí)行結(jié)果會(huì)同步到future中,這個(gè)過程會(huì)持續(xù)到所有的task執(zhí)行結(jié)束;
以上內(nèi)容為大家介紹了python的異步框架模型,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.jsszjs.cn/