Flutter 性能優化技術與最佳實踐
已發表: 2023-04-11Flutter 是一個強大的跨平台框架,用於使用單個代碼庫構建具有視覺吸引力和本地編譯的應用程序。 使用此框架,您可以為 Web、移動和桌面創建解決方案。 Flutter 為 iOS 和 Android 設備上的應用程序提供了類似原生的外觀和感覺。 Flutter 具有許多其他優勢,例如靈活性和應用程序開發速度。 它深受全球軟件開發團隊的喜愛。
然而,要從這個驚人的框架中獲得最佳結果,您必須在開發過程中註意 Flutter 應用程序的性能調優。 優化不佳的 Flutter 應用程序可能會變慢且無響應,消耗更多電量,並且在開發過程中需要更多時間和資源。 這將對用戶體驗和應用商店評級以及應用所有者的預算產生不利影響。 但通過實施正確的性能技術和策略,您可以開發出高性能的 Flutter 應用程序,提供流暢的用戶體驗。 這篇文章討論了 Flutter 性能優化應遵循的最佳實踐。
Flutter 性能優化最佳實踐
使用小部件而不是函數
使用 Widgets 而不是函數是優化 Flutter 應用程序性能的關鍵技術。 函數定義應用程序的行為並操作數據,而小部件是應用程序用戶與之交互的 UI 構建塊。 如果您使用小部件而不是功能,您的 Flutter 移動應用程序將具有交互式且視覺上吸引人的 UI。
以下是一些示例,說明如何在 Flutter 應用程序中使用 Widgets 而不是 Functions。
自定義小部件創建
開發人員通常會定義一個函數來生成一段 UI。 但是,有一種更好的生成 UI 的技術:構建一個封裝用戶界面及其行為的自定義小部件。 此方法將允許您在應用程序的各個部分重用小部件,並且您的代碼將變得更加模塊化和可維護。
內置小部件的使用
如果您不想創建自定義小部件,您可以從 Flutter 框架提供的大量內置小部件中進行選擇。 如果您使用這些內置小部件,則無需編寫自定義代碼即可開發複雜的界面。 例如,TextField 小部件可幫助您創建文本輸入字段,而 ListView 小部件可讓您顯示可滾動的項目列表。
組合多個小部件
要創建更複雜的用戶界面,建議組合多個小部件。 例如,您可以使用行或列小部件水平或垂直堆疊或對齊多個小部件。
將大型小部件分解為子小部件
盡可能使用無狀態小部件是一種很好的做法。 在狀態更改期間,Flutter 會重新繪製有狀態的小部件。 這意味著開發人員必須重建整個小部件。 而且,如果構建樹的大小很大,您將需要多種資源來重建它。 要解決此問題,請保持您的小部件模塊化和小型化以最小化構建函數的大小。 簡而言之,將大型部件分解為更小的子部件。
通過使用小部件而不是功能,您的應用程序 UI 將更加靈活和可重用。 但是,函數是操作數據和定義應用程序行為所必需的。 因此,最有經驗的 Flutter 應用程序開發人員遵循的最佳實踐是將函數與小部件一起使用。
優化佈局並使用“const”關鍵字
Flutter 應用程序佈局的複雜性是影響應用程序性能的關鍵因素之一。 避免使用嵌套佈局; 僅在必要時使用它們。 您還應該嘗試使您的小部件樹盡可能淺。
使用“const”關鍵字是優化 Flutter 應用程序性能的一種流行做法。 在創建自定義小部件或使用內置的 Flutter 小部件時,請盡可能使用“const”關鍵字。 這種做法將使您的小部件不可變。 它將最大限度地減少重建小部件的需求,從而提高性能。 原因如下——如果您使用“const”,Flutter 開發環境將只重建需要更新的小部件。 當 setState 調用發生時,小部件不會發生變化,並且不會發生小部件重建。 另一個推薦的做法是節省 CPU 週期並將它們與“const”構造函數一起使用。
使用異步編程技術
在Flutter應用開發過程中,您必須檢查代碼是同步運行還是異步運行。 使用異步編程技術,您可以避免阻塞主線程,這將保持 Flutter 應用程序的響應能力。 但是,異步編寫 Flutter 應用程序具有挑戰性; 升級和調試等任務變得難以執行。 要解決此問題,請使用“Futures”和“async/await”等異步編程技術。 例如,使用'async/await',Flutter 開發者可以用同步風格編寫異步代碼,這可以增加代碼的可讀性和可維護性。
看看如何在 Flutter 中使用“async/await”。
步驟1
使用 'async' 關鍵字,在函數定義之前定義一個異步函數。
未來的 fetchData() 異步 {
// ...
}
第2步
在異步函數中使用 await 關鍵字來等待異步操作的結果。
未來的 fetchData() 異步 {
最終響應 = await http.get('https://example.com/data');
// ...
}
在這裡,函數 http.get() 返回一個 Future。 這表示可能需要一些時間才能完成的異步操作。 關鍵字 await 使程序能夠在繼續之前等待此操作的結果。
步驟 3
調用異步函數時,使用 await 關鍵字等待函數完成。
等待獲取數據();
關鍵字 await 將使程序能夠在繼續執行下一行代碼之前等待函數 fetchData() 完成。
在 16 毫秒內構建和渲染幀
在 16 毫秒內在您的應用程序中創建和渲染幀是另一種常見的 Flutter 應用程序性能優化技術。 創建和渲染任務需要兩個獨立的線程。 對於這些任務中的每一個,你有 16 毫秒。 但是,為了避免延遲並提高應用程序的性能,您需要將這 16 毫秒降低到 8 毫秒。 這意味著在 8 毫秒內開發幀並在 8 毫秒內渲染它,以便總時間不超過 16 毫秒。
總而言之,在 60 Hz 顯示器中在 16 毫秒內創建和渲染幀。 您可能想知道縮短時間是否會影響顯示質量。 答案是不。 將幀開發和渲染的總時間降低到 16 毫秒不會導致任何可見性差異。 相反,它將提高設備的電池壽命並防止熱問題。 這種方法還將大大加快應用程序在較小尺寸設備上的性能。 您的 Flutter 應用程序的動畫非常流暢,您的用戶將體驗到令人愉悅的用戶體驗。
限制不透明度的使用
將 Opacity 小部件和 Clipping 的使用減少到最低限度。 當您使用 Opacity 時,它會導緻小部件在每一幀後自行重建。 這可能會影響 Flutter 應用程序的性能,如果有動畫則更是如此。 為避免這種情況,您可以直接將不透明度應用於圖像,而不是使用不透明度小部件。 這將提高任務的速度並減少資源使用。
不透明度小部件允許您通過將另一個小部件包裹在其中來隱藏屏幕上的另一個小部件。 許多人使用不透明度小部件來隱藏特定的小部件。 隱藏小部件的做法在 Objective-C 等編程語言中很常見。 但在 Flutter 中,將小部件在屏幕上隱藏時間過長的方法可能會變得代價高昂。 這種方法有一種更具成本效益的替代方法。 您可以使用一種無需文本小部件即可重建小部件的方法來重建小部件而不是隱藏它。 而且,如果您希望在屏幕上顯示該小部件,您可以使用 Visibility 小部件而不是 Opacity。 它不涉及任何分數不透明度值。 可見性有兩種狀態:可見和不可見。
減小應用程序大小
在應用程序開發過程中,開發團隊通常最終會使用多個包、代碼、小部件和腳本。 但是,存儲如此大量的數據可能會消耗大量內存,因此不利於應用程序的性能。
這個問題可以通過使用名為 Gradle 的工具來解決。 此工具可幫助您減小應用程序的大小。 為此,您還可以使用 Google 引入的打包系統。 此打包系統允許您構建 Android 應用程序包。 使用應用程序包,您可以從 Google Play 商店下載原始代碼。 在這裡,您會找到與平台架構和設備兼容的應用程序。
最小化網絡請求
網絡請求的數量會影響 Flutter 應用程序的性能。 盡量減少網絡請求。 您可以使用 StreamBuilder 或 FutureBuilder 等緩存機制來避免重複的網絡請求。
使用有效的數據結構
當您需要在 Flutter 應用程序中處理大量數據時,請避免使用龐大的數據結構,例如地圖或列表。 相反,請考慮使用高效的數據結構,例如 LinkedHashMap 或 Set。 這些數據結構在性能和內存使用方面表現得更好。
優化圖像
圖像可能會成為性能問題的根源,特別是當它們非常大並且沒有適當優化時。 這就是為什麼您應該壓縮圖像並適當調整它們的大小。 為此,您可以使用“flutter_svg”等工具。 此工具可幫助您渲染圖形而不是光柵化圖像。
使用 Flutter 性能工具
Flutter 自帶多種性能優化工具。 這些工具使 Flutter 應用程序開發人員能夠檢查和提升 Flutter 應用程序的性能。 例如,Flutter DevTools 允許您根據 CPU 利用率、內存使用率和幀速率等指標分析和可視化應用程序的性能。
執行應用程序分析
Flutter 性能測試至關重要。 定期分析您的 Flutter 應用程序,以識別 Dart 代碼中的性能問題。 此類問題的一些示例是輸入/輸出、帶寬和缺乏卡頓。 儘早解決問題。 諸如 Flutter Observatory 之類的工具將幫助您識別成本高昂的操作並對其進行優化。
結束語
優化 Flutter 應用程序的性能非常重要。 優化的 Flutter 應用程序可確保設備兼容性、提供出色的用戶體驗、延長電池壽命、最大限度地降低應用程序開發成本並提高應用程序商店排名。 前面提到的 Flutter 性能優化技術是全球無數開發人員信賴的最著名實踐。 因此,請與專業且經驗豐富的 Flutter 應用程序開發公司合作。 一家精通的公司將按照最佳實踐和智能策略執行您的項目,為您提供高性能的 Flutter 最終產品。