Flutter vs React Native vs Native:深度性能比較

来源:https://www.cnblogs.com/mengqd/archive/2020/07/02/13222676.html
-Advertisement-
Play Games

老孟導讀:這是老孟翻譯的付費文章,文章所有權歸原作者所有。 歡迎加入老孟Flutter交流群,每周翻譯2-3篇付費文章,精彩不容錯過。 原文地址:https://medium.com/swlh/flutter-vs-react-native-vs-native-deep-performance-co ...


老孟導讀:這是老孟翻譯的付費文章,文章所有權歸原作者所有。

歡迎加入老孟Flutter交流群,每周翻譯2-3篇付費文章,精彩不容錯過。

原文地址:https://medium.com/swlh/flutter-vs-react-native-vs-native-deep-performance-comparison-990b90c11433

讓我們比較流行的移動開發工具在日常生活中的FPS,CPU,記憶體和GPU性能。

研究背後的故事

inVerita及其移動開發團隊不斷研究市場上提供的跨平臺移動解決方案的性能,以回答哪種技術最適合您的產品,是 Flutter 或 React Native(或 Native)甚至是職業(原文是:maybe even career),這就是 Flutter vs React Native vs Native 第一篇文章出現的原因。是的,這頗有爭議,因為有人可以說我們不是每天使用React Native進行多次計算(可能是這種情況),但是在這種情況下,Flutter或Native應用程式可以更好地執行CPU繁重的任務。

因此,在本文中,我們決定研究UI的性能,該性能對日常使用移動應用程式的用戶影響更大。

衡量UI性能很複雜,這要求工程師在每個平臺上以相同的方式實現相同的功能。我們將 GameBench 作為測試工具,並確保我們保持客觀性(這並沒有改變我們在很多方面都非常喜歡Flutter的事實:),並且仍在運行許多React Native和Native項目)。 GameBench有很多改進空間,但我們的目標是設法將每個應用程式置於一個測試環境中。

源代碼是開放的,因此請嘗試並與我們分享您的想法。 UI動畫通常在不同平臺上使用不同的工具,因此我們將所有內容都縮小到每個平臺支持的庫中(但只有一種情況),或者至少我們做了能夠做到的一切。測試結果可能會有所不同,並且取決於您的實施方法,我們相信您作為特定技術的潛在真正專家可以將您的特定工具集推到極限,使其超過我們的數量,如果您這樣做,我們將非常高興。現在,讓我們看一下案例。

硬體信息:

為了進行測試,我們使用了價格合理的小米Redmi Note 5和iPhone 6s。

倉庫地址

https://github.com/InVeritaSoft/Mobile_frameworks_UI-benchmarks

用例1 —列表視圖基準

我們使用Native,React Native和Flutter在Android和iOS上實現了相同的UI。我們還使用Android上的RecyclerView.SmoothScroller來自動化滾動速度。在iOS和React Native上,我們使用了帶有計時器的方法,並以編程方式滾動到位置。在Flutter上,我們使用ScrollController平滑滾動列表。在每種情況下,我們在列表視圖中都有1000個項目,並且滾動時間相同以到達最後一個列表元素。在每種情況下,我們都使用每個平臺具有不同庫的圖像緩存。更多細節可以在源代碼中揭示。

在這種情況下使用的第三方庫:

iOS:

  • 載入和緩存圖像 — Nuke

Android:

  • 載入和緩存圖像 — Glide

React Native

  1. 所有測試均顯示出大致相同的FPS。
  2. 與Flutter和React Native相比,Android Native使用的記憶體只有一半。
  3. React Native需要最多的CPU開發。原因是在JS和本機代碼之間使用JSBridge,這會導致序列化和反序列化方面的資源浪費。
  4. 關於電池開發,Android Native具有最佳效果。 React-native落後於Android和Flutter。運行連續動畫會在React Native上消耗更多電池電量。
iPhone 6s test

  1. FPS,React Native的結果比Flutter和Swift差。原因是無法在iOS上使用IoT編譯。
  2. 記憶體。 Flutter與Native在記憶體消耗上幾乎一樣,但在CPU上仍然較重。在此測試中,React Native遠遠落後於Flutter和native。
  3. Flutter和Swift之間的區別。當iOS Native積極使用GPU時,Flutter積極使用CPU。 Flutter中的協調會增加CPU的負載。

用例2 —繁重的動畫測試

如今,大多數在Android和iOS上運行的手機都具有強大的硬體。在大多數情況下,使用常規的商業應用程式時,不會發現fps下降。因此,我們決定對重型動畫進行一些測試。重得足以導致fps下降。我們使用了在Android,iOS,React Native上使用Lottie進行動畫處理的矢量動畫,併在Flutter上使用了與Flare相同的動畫。

Android,iOS,React Native 使用 Lottie 動畫,Flutter 使用 Flare

Android
  1. Android和React Native在性能上有相似之處。很明顯,因為Lottie for React Native使用本地方式(16–19%CPU,30–29 FPS)。
  2. Flutter的結局令人驚訝,在演出中有點糟。 (12%的CPU和9 FPS)。

我們發現從網格中刪除一個特定的動畫會使Flutter上的FPS最高提高40%。我們認為Flare較重且未針對此類任務進行優化,這就是Flutter導致FPS下降的原因。

怪這一個:

  1. Android需要最少的記憶體(205 Mb); React Native需要280 Mb,Flutter需要266 Mb。
  2. 冷啟動應用程式。根據此指標,Flutter處於領先地位(2秒)。對於Android Native和React Native,大約需要4秒鐘。
iOS
  1. iOS和React Native在此測試中的結果幾乎與Lottie for React Native使用本地方法相同。
  2. Flare和Flutter不會令人驚訝。Flare 還有很長的一段路要走。
  3. iOS Native需要最少的記憶體量(48 Mb)。 React Native需要135 Mb,Flutter需要117 Mb。
  4. 冷啟動應用程式。根據此指標,Flutter處於領先地位(2秒)。對於iOS和React Native,大約需要10秒鐘。

請註意:在這種情況下,我們為Flutter使用了一個不同的庫,該庫比我們在其他平臺上使用的庫重得多,這可能是fps下降的原因。

用例3-更重的動畫會測試旋轉,縮放和淡入淡出。

在此測試中,我們比較了動畫200張圖像時的性能。刻度旋轉和淡入淡出動畫同時執行。

Android
  1. Native 顯示出最佳性能和最有效的記憶體消耗。
  2. Flutter顯示出非常接近本機fps,並且記憶體開銷增加了兩倍,但性能仍然不錯。
  3. React Native-在這種情況下表現不佳。

iOS
  1. iPhone 6s足夠強大,在所有3種情況下都不會降低fps。
  2. Native 使用的資源較少,而GPU則最多使用。
  3. React Native主要使用CPU進行渲染,而Flutter使用GPU。
  4. React Native使用了更多的記憶體。

總結

對於具有次要動畫和閃亮外觀的常規商務應用程式,技術根本不重要。但是,如果要製作一些繁重的動畫,請記住,Native具有最強大的性能。接下來是Flutter和React Native。我們絕對不建議在CPU繁重的操作中使用React Native,而Flutter從CPU和記憶體的角度來看都非常適合此類任務。

您選擇的工具取決於您的特定產品和業務案例。如果您要開發單平臺MVP,請使用Native,但請記住,Flutter應用程式可以為移動,Web和桌面環境構建,因此Flutter可能會成為跨平臺開發之王未來並非遙不可及,直到今天,Flutter還是對Native開發工具進行了非常不錯的競爭,尤其是在您的開發預算不太緊張但您仍在尋找應用程式性能不錯的情況下。

我們面對這樣一個事實,即可能有許多因素會影響每種技術的實施和基準,並且你們當中許多人可能是特定平臺的真正專家,他們可能會從更多受歡迎的工具中擠出更多的錢。我們通過為每個要測試的應用程式創建一個單一的環境以及一套用於衡量性能的工具,試圖為流程帶來儘可能多的透明度,我希望您喜歡這樣的結果。再一次,我們的移動團隊和Flutter團隊很高興收到並承擔您所有反饋和建議的重擔。

交流

老孟Flutter博客地址(330個控制項用法):http://laomengit.com

歡迎加入Flutter交流群(微信:laomengit)、關註公眾號【老孟Flutter】:


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

-Advertisement-
Play Games
更多相關文章
  • 當下流行的前後端分離項目,常遇跨域問題,現從兩點,解決跨域問題 1.跨域本質:由於瀏覽器的同源策略 同源策略本是瀏覽器最基本的安全功能,是為了防止從一個域上載入另一個域上的信息,舉個例子:A有一個百寶箱,B有一個百寶箱,各自的百寶箱隨便取,但A要是取B的,或者B要是取A的,就會被拒絕 當協議,功能變數名稱, ...
  • 安裝了react-redux後,npm start報下麵錯誤 Failed to compile. ./node_modules/[email protected]@react-redux/es/connect/mapDispatchToProps.js Module not found: Can ...
  • 據統計,國外的前端開發人員和後端開發人員比例約為1:1,但是國內比例卻在1:3以下,web前端開發職位的人才缺口巨大。 根據網上統計數據,上海Web前端開發工程師這一職位的月平均收入為1.5萬元,工作經驗達到3年的web前端工程師甚至達到3萬元。 而且Web前端工程師一般工作1年左右,年薪一般就都能 ...
  • 作者:凹凸曼 - yuche 從 Taro 第一個版本發佈到現在,Taro 已經接受了來自於開源社區兩年多的考驗。今天我們很高興地在黨的生日發佈 Taro 3(Taro Next)正式版,希望 Taro 未來的更多兩年能像一名共產主義戰士一樣經受住更多的考驗。以下是 Taro 3 的一些新增特性: ...
  • css三大特性 層疊性: 如果一個屬性通過兩個相同選擇器設置到同一個元素上,相同的屬性就會出現衝突,那麼這個時候一個屬性就會將另一個屬性層疊掉,採用的是就近原則 繼承性: 子標簽會繼承父標簽的某些樣式 一般以font­,line­,color,text­,list­,都能繼承 備註 : a標簽不能繼 ...
  • 預覽地址 http://106.12.212.110:8077/#/ 上期我們說瞭如何創建項目並把各個項目的文件結構創建好後這期我們來說如何畫出圖中代寫線段 首先我們在src/components/Render.vue中添加一下引用 import zrender from 'zrender' imp ...
  • html簡述: HTML 指的是超文本標記語言 (Hyper Text Markup Language)是用來描述網頁的一種語言。 HTML 不是一種編程語言,而是一種標記語言 (markup language)。 標記語言是一套標記標簽 (markup tag)。 作用:網頁是由網頁元素組成的 , ...
  • 開放埠規劃: mysql-develop:3407 mysql-test: 3408 mysql-release: 3409 ps: 1.不推薦使用預設埠-3306,建議自定義埠 2.如果採用阿裡雲伺服器,在安全組開放埠 3.自建伺服器依據實際情況打開防火牆開放埠[各個系統防火牆不一樣,操 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...