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.dietsnews.net/