【Flutter】性能優化總結

【Flutter】性能優化總結

Flutter 性能優化是提升應用流暢度、響應速度和用戶體驗的關鍵。可以從以下幾個方面進行優化:


一、UI 構建與布局優化

1、避免不必要的重建

  • 使用 const 構造函數:如 const Text('Hello'),可以減少 Widget 重建。
  • 使用 const 修飾靜態 Widget 樹
  • 拆分大 Widget 樹:將大的 build 函數拆分成多個小組件。

2、使用 RepaintBoundary

  • 將頻繁變化的組件用 RepaintBoundary 包裹,減少不必要的重繪區域。
RepaintBoundary(child: YourWidget(),
);

RepaintBoundary 是 Flutter 中非常重要的性能優化工具,它的核心作用是隔離重繪區域,從而減少不必要的重繪,提高性能。好處如下:

  • 減少不必要的重繪;
  • 提升復雜頁面性能;
  • 配合性能調試工具;
  • 緩存機制(圖層緩存);

3、避免嵌套過深的布局

  • LayoutBuilderMediaQueryFlexible 替代部分嵌套 ContainerPadding

二、列表渲染優化

1、使用 ListView.builder 替代 ListView

  • 懶加載構建每一個 item,避免一次性渲染所有 item。

2、使用 AutomaticKeepAliveClientMixin 保持頁面狀態

  • 避免 Tab 切換時頻繁 rebuild。
class MyPage extends StatefulWidget {_MyPageState createState() => _MyPageState();
}class _MyPageState extends State<MyPage>with AutomaticKeepAliveClientMixin {bool get wantKeepAlive => true;
}

三、圖像優化

1、使用 flutter_cache_manager 緩存圖片

  • 避免網絡重復加載大圖。

2、用合適的分辨率加載圖片

  • 盡量使用 WebP 或壓縮后的圖片資源。

3、用 FadeInImage.memoryNetwork 替代 Image.network

  • 提供占位圖,有加載過渡動畫,體驗更好。

四、性能工具使用

1、使用 DevTools 分析性能

  • CPU/內存快照(Memory、CPU Profiler)
  • 重繪區域(Performance Overlay)
  • Widget rebuild 追蹤(Rebuild Tracker)
flutter run --profile
flutter pub global activate devtools

五、狀態管理優化

1、避免 setState 影響全局

  • setState() 控制在局部組件范圍,避免刷新整個 widget 樹。
  • 使用更輕量級的狀態管理工具如 ProviderRiverpodValueNotifier 等。

六、異步任務與卡頓處理

1、大任務用 compute()Isolate

  • 避免在 UI 線程中執行大量計算/IO,如 JSON 解析。
compute(parseJson, jsonString);

2、異步加載使用 FutureBuilderAsyncSnapshot

  • 顯示 loading 狀態,避免空白或卡死頁面。

七、網絡優化

1、Dio 加緩存插件(如 dio_http_cache

  • 避免重復網絡請求,提高響應速度。

2、合理使用 Gzip、緩存策略、分頁加載

  • 尤其在圖片、長列表、分頁數據中非常有效。

八、代碼和資源清理

  • 刪除未使用的資源、圖片、字體等
  • 精簡依賴包,避免引入體積大但功能冗余的庫
  • 使用 flutter build apk --split-per-abi 減小安裝包體積

九、總結表格

優化方向推薦做法
Widget 構建const、拆分組件、RepaintBoundary、避免嵌套
列表性能使用 ListView.builderkeepAlive
圖片優化緩存、壓縮、WebP、占位圖
狀態管理避免全局 setState,用 Provider/Riverpod
異步任務computeIsolate,避免主線程阻塞
工具分析DevTools、Performance Overlay、Widget Inspector
網絡優化緩存、分頁、Gzip、壓縮響應
減小包體積刪除未用資源、依賴優化、APK 分包

十、關于作者(ZFJ_張福杰)

  • 官網:https://zfjsafe.com
  • 博客:https://zfj1128.blog.csdn.net
  • Github:https://github.com/zfjsyqk
  • Gitee:https://gitee.com/zfj1128
  • 打賞:https://zfjsafe.com/paycode

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/84873.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/84873.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/84873.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

5、ZYNQ PL 點燈--流水燈

目錄 1、 概述 2 、硬件電路 3、 新建 VIVADO 工程 4、 添加工程文件 6、編寫流水燈功能的Verilog代碼 7 、添加管腳約束文件 8、 RTL 仿真 8.1 添加仿真測試源碼 8.2 仿真結果 9、 編譯并且產生 bit 文件 10、 下載程序 11、實驗結果 ?編輯12、總結 1、 概述 本…

HTML5 浮動

1. 常見網頁布局 1-3-1布局 1-2-1布局 2. 標準文檔流 3. display屬性? display&#xff1a; block 給span元素設置成block display&#xff1a; inline 給div元素設置成inline display&#xff1a; inline-block 給div和span元素設置為inline-block display&#xff1a; no…

若依使用RedisCache需要注意的事項

存入redis對象的時候會帶一個type字段&#xff0c;此處需要注意 存入方&#xff1a; 此處需要注意&#xff0c;存入redis的時候會帶一個type&#xff0c;也就是類的路徑名 redisCache.setCacheObject(screenPlayQueueName, userDemondDto,userDemondDto.getPlayDuration().in…

【STM32的通用定時器CR1的CKD[1:0]: 時鐘分頻因子 (Clock division)】

在 STM32 的通用定時器&#xff08;如 TIM2, TIM3, TIM4, TIM5 等&#xff09;中&#xff0c;CR1 (Control Register 1) 寄存器中的 CKD[1:0] (Clock division) 位域是一個與抗干擾和數字濾波相關的設置&#xff0c;它并不直接影響定時器計數器 (CNT) 的計數頻率&#xff08;計…

渲染學進階內容——機械動力的渲染系統(2)

Flywheel代碼 這篇來研究一下實例 InstanceHandle 接口深度解析 接口核心作用 InstanceHandle 是 Flywheel 渲染引擎中的 GPU實例句柄 接口,它提供了對底層渲染實例的直接控制能力。這個接口是**實例化渲染(Instanced Rendering)**系統的核心操作接口,與之前討論的 Vis…

Redis:極速緩存與數據結構存儲揭秘

Redis —— 這個強大又靈活的 開源、內存中的數據結構存儲系統。它常被用作數據庫、緩存、消息代理和流處理引擎。 核心特點 (為什么它這么受歡迎&#xff1f;)&#xff1a; 內存存儲 (In-Memory): 數據主要存儲在 RAM 中&#xff0c;讀寫操作直接在內存中進行。核心優勢&…

vulnyx Diff3r3ntS3c writeup

信息收集 arp-scan nmap 這里默認的話是只有80端口的&#xff0c;這個22端口是我拿到root后開的 獲取userFlag 直接上web看看 掃個目錄 把網頁拉到最下面可以看到一個文件上傳點 我們嘗試上傳一個php文件 失敗了&#xff0c;那xxx呢 上傳成功了&#xff0c;看來后端的后綴名…

【構建】CMake 構建系統重點內容

CMake 構建系統重點內容 1 基本語法與結構 cmake_minimum_required() 指定使用的最低 CMake 版本&#xff0c;防止不同版本行為不一致&#xff1a; cmake_minimum_required(VERSION 3.16)project() 定義項目名稱、語言和版本&#xff1a; project(MyApp VERSION 1.0 LANGU…

Packagerun:VSCode 擴展 快捷執行命令

Packagerun&#xff1a;VSCode 快捷命令擴展&#xff08;兼容cursor&#xff09; Packagerun 是一個為 前端和node開發者設計的 VSCode 擴展&#xff0c;旨在簡化 package.json 中腳本的執行&#xff0c;并支持自定義命令以提升開發效率。通過右鍵菜單、快捷鍵或自定義配置&am…

【C語言】計算機組成、計算機語言介紹

1.1 計算機組成 1946年2月14日&#xff0c;由美國軍方定制的世界上第一臺電子計算機“電子數字積分計算機”( ENIAC Electronic Numerical And Calculator)在美國賓夕法尼亞大學問世。 計算機(俗稱電腦)堪稱是人類智慧的結晶&#xff0c;隨著計算機的不斷發展&#xff0c;各行各…

(九)山東大學軟件學院項目實訓-基于大模型的模擬面試系統-面試對話標題自動總結

面試對話標題自動總結 主要實現思路&#xff1a;每當AI回復用戶之后&#xff0c;調用方法查看當前對話是否大于三條&#xff0c;如果大于則將用戶的兩條和AI回復的一條對話傳給DeepSeek讓其進行總結&#xff08;后端&#xff09;&#xff0c;總結后調用updateChatTopic進行更新…

降階法求解偏微分方程

求解給定的四個偏微分方程,采用降階法,令 v = u x v = u_x v=ux?,從而將原方程轉化為關于 v v v 的一階方程。 方程 u x y = 0 u_{xy} = 0 uxy?=0 令 v = u x v = u_x v=ux?,則方程變為 v y = 0 v_y = 0 vy?=0。解得 v = C 1 ( x ) v = C_1(x) v=C1?(x),即 u …

提的缺陷開發不改,測試該怎么辦?

經歷長時間的細致檢查&#xff0c;逐條執行數十條測試用例&#xff0c;終于發現一處疑似缺陷。截圖留存、粘貼日志&#xff0c;認真整理好各項信息&#xff0c;將它提交到缺陷管理系統。可不到五分鐘&#xff0c;這條缺陷就被打回了。開發人員給出的回復十分簡潔&#xff1a;“…

【Flutter】Widget、Element和Render的關系-Flutter三棵樹

【Flutter】Widget、Element和Render的關系-Flutter三棵樹 一、前言 在 Flutter 中&#xff0c;所謂的“三棵樹”是指&#xff1a; Widget Tree&#xff08;部件樹&#xff09;Element Tree&#xff08;元素樹&#xff09;Render Tree&#xff08;渲染樹&#xff09; 它們是…

IO之詳解cin(c++IO關鍵理解)

目錄 cin原理介紹 控制符(hex、oct、dec) cin如何檢查輸入 cin與字符串 cin.get(char ch) cin.get(void) istream &get(char*,int) istream &get(char*,int,char) istream &getline(char*,int); 遇到文件結尾EOF 無法完成一次完整輸入&#xff1a;設置f…

Bootstrap 5學習教程,從入門到精通, Bootstrap 5 分頁(Pagination)知識點及案例代碼(13)

Bootstrap 5 分頁&#xff08;Pagination&#xff09;知識點及案例代碼 Bootstrap 5 提供了強大的分頁組件&#xff0c;幫助開發者輕松實現分頁功能。以下是關于 Bootstrap 5 分頁的詳細語法知識點以及一個完整的案例代碼&#xff0c;包含詳細注釋&#xff0c;幫助初學者快速上…

Dina靶機滲透

1.信息查詢 1.1. Ip查詢 arp-scan -l 192.168.220.137 1.2. 端口收集 nmap -T4 -A -p- 192.168.220.137 1.3. 目錄掃描 dirsearch -u 192.168.220.137 -e* -i 200 通過訪問 robots.txt 文件發現有些禁止訪問得目錄 User-agent: *Disallow: /ange1Disallow: /angel1Dis…

通俗理解存儲過程注入

【通俗理解】存儲過程注入&#xff1a;SQL注入的“豪華升級版” 一、從廚房做菜說起&#xff1a;為什么需要存儲過程&#xff1f; 想象你經營一家連鎖餐廳&#xff0c;每道菜的制作流程非常復雜&#xff08;比如“招牌紅燒肉”需要先焯水、再炒糖色、最后慢燉1小時&#xff09…

【算法】基于中位數和MAD魯棒平均值計算算法

問題 在項目中&#xff0c;需要對異常值進行剔除&#xff0c;需要一種魯棒性比較好的方法&#xff0c;總結了一個實踐方法。 方法 基于中位數和MAD&#xff08;中位數絕對偏差&#xff09;的魯棒平均值計算算法的詳細過程&#xff0c;按照您要求的步驟分解&#xff1a; 算法…

插入點(position) 和對齊點(AlignmentPoint)詳解——CAD c#二次開發

在 AutoCAD 中&#xff0c;文本對象的位置由插入點&#xff08;position&#xff09; 和對齊點&#xff08;Alignment Point&#xff09; 共同控制&#xff0c;兩者的關系取決于文本的對齊方式。以下是詳細說明&#xff1a; 一、插入點與對齊點的定義 1. 插入點&#xff08;p…