Flutter 下載篇 - 貳 | 當下載器遇上切換網路庫

来源:https://www.cnblogs.com/xuge2it/archive/2023/03/04/17177620.html
-Advertisement-
Play Games

需求背景 繼上篇《Flutter 下載篇 - 壹 | flutter_download_manager 源碼解析》中詳細介紹了 flutter_download_manager 用法和原理。在優缺點中提到,該庫純 Dart 實現,支持下載管理,暫停,恢復,取消和斷點續傳。其中有個缺點是網路庫與 di ...


需求背景

繼上篇《Flutter 下載篇 - 壹 | flutter_download_manager 源碼解析》中詳細介紹了 flutter_download_manager 用法和原理。在優缺點中提到,該庫純 Dart 實現,支持下載管理,暫停,恢復,取消和斷點續傳。其中有個缺點是網路庫與 dio 強耦合,不支持自定義網路庫擴展。

有人會說: dio 這麼牛逼,直接用不就好了,為啥還要支持別的網路庫,沒事別瞎折騰。

我想說:

  1. 世界不只有一種聲音,那不然多無趣。
  2. 第三方庫對應用本身來說是黑盒,開發者一般疏於關註其功能改動對應用影響除非產生重大事故,這種不可控的情況應謹慎。
  3. 設計上遵循 DIP 原則,抽象不要依賴具體實現細節,具體細節依賴抽象,我們需要抽象網路層來給項目依賴而非直接依賴 dio。
  4. 快速切換到其他網路庫。

本文將從現狀出發,一步步帶你解耦 flutter_download_manager 中的網路庫。

現狀說明

從類圖上整體瞭解 flutter_download_manager 類設計過程中對 dio 強耦合概括,然後通過代碼具體講解。

類圖體現

Untitled.png

代碼體現

耦合點一:dio.CancelToken

Untitled 1.png

每個下載任務請求中都會使用到 dio:CancelToken 通過 dio 網路庫間接實現任務的取消功能。

耦合點二:dio.download

cancelToken.cancel() 算依賴 CancelToken

Untitled 2.png

如上簡寫代碼中調用鏈關係,最終調用鏈及對 dio 依賴關係總結:

下載庫對 dio 的依賴在於: CancelToken 和 download 方法

Untitled 3.png

如何定製網路庫

通過上述對現狀分析總結,結合設計基本原則:封裝變化將不變從變化中隔離出來。其中變化的就是網路庫的下載,CancelToken 和取消功能。只用封裝這部分變化,將網路庫下載和 Token 抽象出來進行封裝。

1. 網路層設計

目的:讓 flutter_download_manager 與 dio.download 解耦。

思路:將網路相關操作抽象成介面,依賴註入到 downloadManager 對象中。

實施步驟

  1. 抽象網路層介面

考慮到 download 返回 Future 中對象問題,因為會用到 response.statusCode,這裡直接用 dynamic 來,具體可以細化成封裝成 DownloadResponse,其中包含 statusCode 屬性。

Untitled 4.png

  1. customhttpclient 通過依賴註入傳入 DownloadManager,讓其不依賴具體實現而依賴抽象,依賴註入實現對象之間的組合關係提高擴展性。

Untitled 5.png

2. CancelToken 設計

目的:讓 flutter_download_manager 與 dio.CancelToken 解耦。

思路:CancelToken 與取消息息相關,而且必須提供一個 cancel 方法來供 downloadmanager 中暫停等方法使用。考慮到每個 custom_http_client 的 CancelToken 結構體存在不一樣,而 cancel 方法命名多樣性原則,這裡設計一個統一的 DownloadCancelToken 介面,提供 cancel 方法,將其中實現代理給具體網路庫的 CancelToken 對象。

實施步驟

  1. 抽象一個 Token 對象並提供 cancel 方法,並實現一個預設代理其他網路庫的 Proxy 類。

小技巧: 用 Function.apply 是因為它本身支持位置參數和可選參數傳入。

Untitled 6.png

  1. custom_http_client 中抽象一個 DownloadCancelToken 抽象介面供外部使用

Untitled 7.png

3. 下載器設計

目的:下載器與具體實現 downloadmanager 解耦

思路:downloadmanager 中提供了 addDownload 等下載通用方法及下載管理邏輯抽象。這塊存在變化可以有多種實現,也抽象下。

實施步驟:

  1. 下載器抽象成介面

Untitled 8.png

  1. downloadManager 依賴 IDownloader

Untitled 9.png

至此,可定製網路庫改造已全部完成,接下來就可以隔離 dio 網路實現了。

網路庫隔離效果

Untitled 10.png

通過依賴註入到 DownloadManager 中即可。

Untitled 11.png

如此就完成了對 flutter_download_manager 的網路庫擴展改造,實現了一個可定製化的網路框架的下載庫。

完整源碼傳送門

總結

做開閉原則前,最重要的是以最小實現模型為基礎捋清楚代碼中的變與不變。

太棒了!鼓勵自己堅持到底。我希望我為你投入的時間增加了一些價值。

如果覺得文章對你有幫助,點贊、收藏、關註、評論,一鍵四連支持,你的支持就是我創作最大的動力。

❤️ 本文由 聽蟬 原創,歡迎關註公眾號:編程黑板報 原創技術文章第一時間推送。 ❤️


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 頁眉位於文檔中每個頁面的頂部區域,常用於顯示文檔的附加信息,可以插入時間、圖形、公司微標、文檔標題、文件名或作者姓名等;頁腳位於文檔中每個頁面的底部的區域,常用於顯示文檔的附加信息,可以在頁腳中插入文本或圖形。今天這篇文章就將為大家展示如何以編程的方式在在 Word 文檔中添加頁眉和頁腳。下麵是我整 ...
  • 實現背景 最近需要把大數據測試環境的虛擬機遷移到另一臺物理機上,其中資料庫文件過大,一般的上傳文件有大小限制不能超過4GB,可以通過NFS共用目錄解決文件上傳問題。 NFS介紹 NFS介紹NFS 即網路文件系統(Network File-System),可以通過網路讓不同機器、不同系統之間可以實現文 ...
  • 原文:What is a Shell? 註意:本文是對原文的一個翻譯! Shell是一個巨集處理器,用於執行命令。巨集處理器意味著,將文本和符號展開,創建一個更大的表達式。 Unix shell 既是一個命令解釋器,也是一門編程語言。作為一個命令解釋器,它提供了豐富的GUN工具集可以與用戶進行交互。作為 ...
  • 前言 本文展示了一個比較完整的企業項目級別的Makefile文件,包括了:文件調用,源文件、頭文件、庫文件指定,軟體版本號、巨集定義,編譯時間,自動目錄等內容。 1、目錄架構 本文中所採用的目錄架構,在企業項目開發中十分常見:源文件都放在src目錄中,頭文件都放在inc目錄中,並且這兩個目錄都可以有對 ...
  • 1602LCD 是工業上常用的模塊, 在工廠交通運輸設備上經常能見到. 驅動晶元為 HD44780, 1602LCD 的字元顯示為兩行, 每行16個字元, 字元基於5×8的像素矩陣 ...
  • 1、工作應用場景 統計得到每個小時的UV、PV、IP的個數,構建如下表結構: 但是表中數據的存儲格式不利於直接查詢展示,需要進行調整:(以時間分區,去重、聚合等……對結果進行行列轉換) 2、行轉列 (1)多行轉多列 case when函數 功能:用於實現對數據的判斷,根據條件,不同的情況返回不同的結 ...
  • 1、全局排序(Order by) 功能:全局排序,只有1個reducer(用1個Reduce Task完成全局排序,與設置的Reduce Task個數無關) 參數:ASC:升序(預設) DESC:降序 使用:order by放在select語句的結尾 例如: --查詢員工信息按工資降序排列 sele ...
  • 前言 本文是關於使用flutter_download_manager下載功能的實踐和探索。我們將基於flutter_download_manager的功能擴展,改造成自己想要的樣子。在閱讀本文之前,建議先瞭解前兩篇文章: Flutter 下載篇 - 壹 | flutter_download_mana ...
一周排行
    -Advertisement-
    Play Games
  • .NET Core 選項系統的主要實現在 Microsoft.Extensions.Options 和 Microsoft.Extensions.Options.ConfigurationExtensions 兩個 Nuget 包。對於一個框架的源碼進行解讀,我們可以從我們常用的框架中的類或方法入手 ...
  • 最近在工作中遇到一個問題,就是我有多個線程會調用bitmap對象,運行的時候報錯,對象當前正在其他地方使用。第一反應肯定是加鎖啊,於是我就在每個用到bitmap的地方都加了鎖,但是運行之後依然報這個錯 測試代碼如下 using System; using System.Drawing; using ...
  • 一:背景 1. 講故事 前段時間有位朋友微信找到我,說他的程式使用 hsl 庫之後,採集 plc 時記憶體溢出,讓我幫忙看一下怎麼回事,哈哈,貌似是分析之旅中的第二次和 hsl 打交道,既然找到我,那就上 windbg 說話吧。 二:WinDbg 分析 1. 為什麼會記憶體溢出 簡單觀察程式的提交記憶體之 ...
  • 在 IIS 上啟用 Websocket 在 Windows Server 2012 或更高版本上啟用對 WebSocket 協議的支持: 備註 使用 IIS Express 時無需執行這些步驟 通過“管理”菜單或“伺服器管理器”中的鏈接使用“添加角色和功能”嚮導。 選擇“基於角色或基於功能的安裝”。 ...
  • C#-垃圾回收機制(GC) 什麼是GC 官網中有這麼一句話: The garbage collector is a common language runtime component that controls the allocation and release of managed memory ...
  • 呆了2個大屏行業的公司,對大屏幕有一些瞭解,所以整理下所瞭解的觸摸屏相關概念。方便自己以及進入這個行業的小伙伴們,能有個系統、快速的認知。 觸摸屏詳細的知識點,網上其實都有。整理資料過程中,我也瞭解了更多的觸摸屏知識,像聲波屏、光學屏之類的之前就沒接觸。下麵分不同的模塊,給大家介紹 交互觸摸屏類型 ...
  • 近段時間忙於各種項目和對【易排平臺】的優化,沒顧得上分享APS相關的小技巧,回頭看看小公眾號的關註人數早已達1500+,在此爭取時間寫一下這段時間在項目上及平臺優化過程中遇到的一些小技巧,以感謝諸位的關註。過去數月的解決的問題中,涉及最多的是規劃模型中,實現各種時間維度的功能,目前在平臺上也稍有成果 ...
  • 針對大量log日誌快速定位錯誤地方 動態查看日誌 tail -f catalina.ou 從頭打開日誌文件 cat catalina.ou 可以使用 >nanjiangtest.txt 輸出某個新日誌去查看 [[email protected] logs]# cat -n catalina.out |grep 7 ...
  • 前言 RocketMQ是阿裡巴巴旗下一款開源的MQ框架,經歷過雙十一考驗、Java編程語言實現,有非常好完整生態系統。RocketMQ作為一款純java、分散式、隊列模型的開源消息中間件,支持事務消息、順序消息、批量消息、定時消息、消息回溯等 本篇文章第一部分屬於一些核心概念和工作流程的講解;第二部 ...
  • 在java,c#類的成員修飾符包括,公有、私有、程式集可用的、受保護的。 對於python來說,只有兩個成員修飾符:公有成員,私有成員 成員修飾符是來修飾誰呢?當然是修飾成員了。那麼python類的成員包括什麼呢? python成員: 欄位,方法,屬性 每個類成員的修飾符有兩種: 公有成員:內部外部 ...