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