本文由玉剛說寫做平臺提供寫做贊助,版權歸玉剛說微信公衆號全部
原做者:Xiasm
版權聲明:未經玉剛說許可,不得以任何形式轉載android
自從今年google IO大會推出flutter跨平臺開發框架以來,flutter在各個技術論壇裏被吵得如日中天。flutter團隊直言flutter能夠幫助開發者輕鬆實現恆定60fps的性能體驗。這裏附上flutter官方性能介紹:flutter應用程序性能介紹
咱們知道flutter跨平臺的原理是採用dart語言預編譯的方式直接編譯出各個平臺的原生代碼,而不須要相似RN用JavaScript橋接器執行原生代碼。那麼這樣作的性能究竟如何呢?是否能達到和原生同樣的流暢度,是否如官方所說達到恆定60fps的性能體驗?今天咱們就以android爲例從幾個不一樣的維度來實際測試一下!git
咱們分別用 flutter 和 android 原生來編寫一個ui效果如出一轍的 apk,而後打出 release 版本的安裝包,爲了保證測試結果的可靠性,咱們不引入任何第三方庫,只用框架提供的控件作一些簡單ui,這裏附上demo源碼:flutter demo,android demo。好了,咱們打出各自的release版本apk,而後使用AndroidStudio自帶的APK Analyzer進行分析,以下圖:github
經過對比咱們瞭解到,flutter 版的 apk 大小會比 android 原生的多出約 6M 左右,其中核心引擎大約 3.2MB,框架+應用程序代碼大約是 1.25MB,必需的 Java 代碼 .dex 將近 60k,而 assets 文件裏還約有 2.1MB 的 ICU 數據等,單純從安裝包上來講,原生是要優於 flutter 的。微信
爲了測試覆蓋更加充分,咱們分別在 debug 和 release 模式上進行性能測試。而據官方介紹 flutter 的 debug 模式在性能上是要略於 release 版的,因此他們提供了 profile 模式供咱們測試,profile 模式編譯和啓動 Flutter 應用程序幾乎與 release 模式徹底相同。
咱們先看 android 原生的 debug 和 flutter 的 proflle 模式性能對比,這裏咱們用 Android Profiler 進行性能指標檢測,demo 只有一個界面,用 ListView 展現 10000 條數據。下面看圖:app
debug 和profile 模式的性能測試若是你還不放心的話,那麼下面我分別打包出用 flutter 和 android 原生構建出的release apk,而後將手機開啓ROOT權限,以即可以用 Android Profiler 檢測到這兩個版本的進程,進行性能測試。下面看圖:框架
我在打開 app 並鎖定當前進程後,分別在大約第 10 秒的時候,用手指輕輕滑動了 ListView,下面咱們分析下兩種方式的資源佔用狀況。
工具
從上邊兩種模式的性能檢測結果分析咱們能夠總結出,flutter 應用在 CPU 和內存的資源佔用上會比原生方式多一些,因此單純的從性能上來講,android 原生是確定要優於 flutter 的,可是從用戶體驗上來講,二者的滑動一樣順暢無比,幾乎感受不到差異。性能
啓動是咱們衡量一個應用程序性能的重要指標,下面我先經過一個 gif 來演示下 android 版和 flutter 版啓動 app 的體驗:
測試
看得出,android 版和 flutter 版從啓動體驗上來講幾乎不相上下。這裏我大膽作一個猜想,flutter app的啓動機制和原生仍是如出一轍,因此調用啓動 Application 也是建立 ActivityThread 而後最終執行 Application 的 onCreate 方法,因此從啓動上來講相差無幾。下面我貼出 android 原生和 flutter 版的啓動trance文件,動畫
trance 文件幾乎如出一轍,我一度都懷疑是本身弄錯了,而後又仔細確認了一下沒出錯才放心,能夠得出結論,flutter 版的啓動流程跟原生是如出一轍的。
Flutter 官方指出其旨在提供 60 幀/秒的刷新率,60 fps 意味着大約平均每 16 ms 渲染一幀。咱們知道,當 UI 不能平滑的渲染時就會出現掉幀。舉個例子,假若有一幀執行的東西太多,花費了 160 ms 的時間去渲染,這段期間就會產生丟幀現象,從而就會看到動畫出現了明顯的抖動。flutter release 版本是無法去測試渲染指數的,這裏咱們仍是以 profile 模式運行,而後在用官方給咱們提供的 Flutter Inspector 工具去展現 fps 變化。下面看 Gif 圖:
個人手機是小米Note 2,高通驍龍821處理器 4G 內存,性能大概屬於 Anroid 陣營中上等。我打開 app 後先是平穩的滑動 listview,而後又快速的滑動,由圖可看出,刷新率起初恆定在 60fps,當我快速滑動的時候,刷新率大約保持在58~59 之間,因此 flutter 官方所說 fps 恆定在 60fps 仍是可信的。
經過以上的分析,咱們能夠很明確的得出結論,android 原生在內存、CPU 資源佔用方面要低於 flutter,而且安裝包的體積也要小於 flutter,因此,不考慮其餘因素,單純從性能角度來講,android 原生確定是要優於 flutter 的。但 flutter 也有它的優勢,好比跨平臺的開發、毫秒級的熱重載等等,另外跨端開發也逐漸的流行起來,因此,咱們在學好android原生的基礎上,對跨端開發也要抱有積極的心態。