日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

 

在OkHttp3中,其靈活性很大程度上體現(xiàn)在,可以攔截其任意一個環(huán)節(jié),而這個優(yōu)勢便是okhttp3整個請求響應(yīng)架構(gòu)體系的精髓所在:

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

Okhttp請求流程

 

  • 在OkHttp3中,每一個請求任務(wù)都封裝為一個Call,其實現(xiàn)為RealCall。
  • 而所有的策略幾乎都可以通過OkHttpClient傳入
  • 所有全局策略與數(shù)據(jù),除了存儲在允許上層訪問的OkHttpClient實例以外,還有一部分是存儲在只允許包可見的Internal.instance中(如連接池、路由黑名單等)
  • OkHttp中用戶可傳入的interceptor分為兩類,一類是全局interceptor,該類interceptor在請求開始之前最早被調(diào)用,另外一類為非網(wǎng)頁請求的networkInterceptor,這類interceptor只有在非網(wǎng)頁請求中會被調(diào)用,并且是在組裝完成請求之后,真正發(fā)起請求之前被調(diào)用(這塊具體可以參看RealCall#getResponseWithInterceptorChain()方法)
  • 整個請求過程通過RealInterceptorChain#proceed來連接,在每個interceptor中調(diào)用下一個interceptor來完成整個請求流程,并且在回到當(dāng)前interceptor后完成響應(yīng)處理
  • 在異步請求中,我們通過Callback來獲得簡單清晰的請求回調(diào)(onFailure、onResponse)
  • 在OkHttpClient中,我們可以傳入EventListener的工廠方法,為每一個請求創(chuàng)建一個EventListener,來接收非常細(xì)的事件回調(diào)
架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

完整interceptor-chain

OkHttp3中的線程池

OkHttp 中的對所有的任務(wù)采用 NamedRunnable,約束每個執(zhí)行單元給出對應(yīng)的業(yè)務(wù)名稱,以便于線程維護(hù)。

1.異步請求線程池-OkHttp Dispatcher

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

  • 該線程池與Android下的 Executors.newCachedThreadPool() 比較類似;
  • 無任務(wù)上限,自動回收閑置60s的線程,適用于大量耗時較短的任務(wù);
  • 雖然線程池?zé)o任務(wù)上限,但是Dispatcher對入口enqueue()進(jìn)行了把關(guān),最大的異步任務(wù)數(shù)默認(rèn)是64,同一個主機默認(rèn)是5,當(dāng)然這兩個默認(rèn)值是可以修改的,Dispatcher提供的修改接口;

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

 

  • 通過兩個雙端隊列來維護(hù)準(zhǔn)備執(zhí)行的任務(wù)和正在執(zhí)行的任務(wù):Deque<AsyncCall> readyAsyncCalls, Deque<AsyncCall> runningAsyncCalls;
  • 在每個任務(wù)結(jié)束時,都會檢查 readyAsyncCalls 是否有任務(wù),在條件滿足的情況下,按照先進(jìn)先出的原則將任務(wù)移動到 runningAsyncCalls中,并在線程池中執(zhí)行;
架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

異步請求線程池

2.連接池清理線程池-OkHttp ConnectionPool

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

 

  • 該線程池用來清理長時間閑置的和泄漏的連接;
  • 該線程池本身無任務(wù)上限,線程閑置60s自動回收;
  • 雖然任務(wù)無上限,但其通過 cleanupRunning 標(biāo)記來控制只有一個線程在運行,當(dāng)連接池中沒有連接后才會被重新設(shè)置為 false;

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

 

  • 次工作線程會不斷地清理,當(dāng)清理完一遍后超時連接后,根據(jù)當(dāng)前連接池中最近的下一個空閑超時連接計算出一個阻塞時間并阻塞,直到連接池中沒有任何連接才結(jié)束,并將 cleanupRunning 設(shè)為 false;
  • 在每次有連接加入連接池時,如果當(dāng)前沒有清理任務(wù)運行,會加入一個清理任務(wù)到到線程池中執(zhí)行;

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

連接池清理線程池

3. 緩存整理線程池-OkHttp DiskLruCache

 

架構(gòu)分析高效HTTP客戶端OkHttp的核心

 

 

  • 該線程池用于整理本地請求緩存數(shù)據(jù);
  • 緩存的整理包含: 達(dá)到閥值大小的文件,刪除最近最少使用的記錄,在有關(guān)操作達(dá)到一定數(shù)量以后對記錄進(jìn)行重建;
  • 最大運行線程數(shù)1,無需考慮線程安全問題,自動回收閑置60s的線程;

4. HTTP2異步事務(wù)線程池-OkHttp Http2Connection

  • HTTP2采用了多路復(fù)用,因此需要維護(hù)連接有效性,本線程池就是用于維護(hù)相關(guān)的各類HTTP2事務(wù);
  • 線程池本身無任務(wù)上限,自動回收閑置60s的線程;
  • 每一個HTTP2連接都有這么一個線程池存在;


 

分享到:
標(biāo)簽:HTTP
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運動步數(shù)有氧達(dá)人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定