OkHttp學(xué)習(xí)筆記(二)-----事件分發(fā)Dispatcher

OkHttp支持的最大同時請求數(shù)量是64個,最大共同請求主機是5個,那么當(dāng)高并發(fā)當(dāng)情況下,OkHttp是如何管理這些請求的呢?查看源碼可以發(fā)現(xiàn),源碼中有一個Dispatcher

Dispathcer ,Policy on when async requests are executed?
這句話的意思就是這個Dispatcher是當(dāng)多個異步請求執(zhí)行時的代理

但是每一個Dispathcer被使用的時候其實是通過ExecutorService來管理請求的生命周期,如果不使用默認(rèn)的ExecutorService,而自定義一個ExecutorService,那么這個ExecutorService需要支持高并發(fā)。

在Okhttp的Dispathcer可以看到幾個屬性分別是:

1.?maxRequests =64 //最大并發(fā)數(shù)

2.?maxRequestsPerHost =5? ? //最大同時請求主機數(shù)

3.?executorService //執(zhí)行者服務(wù),用于控制請求的生命周期

4. readyAsyncCalls? //異步等待隊列

5. runningAsyncCalls? ? ?//異步執(zhí)行隊列,加入后可以立即執(zhí)行

6.runningSyncCalls //同步執(zhí)行隊列

在學(xué)習(xí)筆記(一)中,已經(jīng)提到,當(dāng)call.enqueue的時候會通過這個dispatcher來調(diào)度線程

還可以通過dispatcher來?

enqueue //執(zhí)行runningAsyncCalls隊列中的call

cancelAll //取消所有call

promoteCalls? ? //將等待隊列中的call加入到執(zhí)行隊列中

finished //請求已經(jīng)完成時調(diào)用,調(diào)用這個方法時會判斷 是否還有call未執(zhí)行,如果存在就執(zhí)行promoteCalls()方法,如果所有請求都完成就執(zhí)行回調(diào)

還可以查看當(dāng)前等待/執(zhí)行隊列中的情況

所以這個dispatcher會根據(jù)不同情況把call加入到不同到不同到隊列中,并且通過excuteservice管理call

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容