0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文快速帶您了解 KMM、Compose 和 Flutter 的現(xiàn)狀 | 開發(fā)者說·DTalk

谷歌開發(fā)者 ? 來源:未知 ? 2022-12-23 20:55 ? 次閱讀

本文原作者: 戀貓de小郭,原文發(fā)布于: GSYTech

又到了喜聞樂見的環(huán)節(jié),「本篇主要是科普 KMM、Compose 和 Flutter 的最新現(xiàn)狀」,對于 Compose 和 Flutter 大家可能并不陌生,但是對于 KMM 也許會(huì)存在疑惑,KMM 全稱 Kotlin Multiplatform Mobile,顧名思義它是用 Kotlin 實(shí)現(xiàn)的跨平臺(tái)框架,那為什么今天突然會(huì)聊到它?

起因如下圖所示,最近有人提及了 KMM,并且用了 "變天" 的詞匯,頓時(shí)就勾起了我的興趣,因?yàn)?KMM 這些年來一直 "不溫不火",可以說很多使用 Kotlin 開發(fā)的 "Androider" 對它都很陌生,難道最近它又有了什么突破性的進(jìn)展?

而在求證一番之后,原來起因來自 10 月初「Android 官方宣布Jetpack 開始要支持 KMM」了,目前Collections和DataStore已經(jīng)可以通過依賴-dev01版本在多平臺(tái)上使用,同時(shí)「KMM 進(jìn)入 Beta 版本階段」。 「所以目前 KMM 變不了天,至少它還處于 Beta 階段,但是 Jetpack 開始支持 KMM 是個(gè)很好的消息,這意味著 KMM 的社區(qū)支持有了官方保證」。
好了,介紹完起因,接下來開始進(jìn)入今天的主題,什么是 KMM、Compose 和 Flutter。

KMM

Kotlin Multiplatform Mobile – KMM 是基于 Kotlin 并應(yīng)用在 iOS 和 Android 的一種跨平臺(tái)技術(shù),它的特點(diǎn)是結(jié)合了跨平臺(tái)和原生開發(fā)協(xié)同開發(fā)的模式,如下圖所示,簡單的理解就是:「從純原生開發(fā)變成了 KMM + 原生 UI 開發(fā)」。27cc7628-82bf-11ed-bfe3-dac502259ad0.png

「使用 KMM 可以把您的業(yè)務(wù)邏輯和基建部分的能力跨平臺(tái)化」,例如網(wǎng)絡(luò)請求、數(shù)據(jù)存儲(chǔ),狀態(tài)上報(bào)等模塊通過 KMM 實(shí)現(xiàn) Android 和 iOS 通用,例如前面介紹的 DataStore 就可以在 iOS 上支持使用。

在官方的介紹里 KMM 的早期使用者有百度、Netflix、VMWare、Philips 等,目前收到的反饋都挺不錯(cuò),而 Beta 版本也意味著現(xiàn)在 KMM 已經(jīng)具備了使用的基礎(chǔ)。

那您可能會(huì)好奇,KMM 支持 Web 嗎?

聊到這個(gè)話題就很有趣,從我的角度上看,我會(huì)說 Kotlin Multiplatform 支持,但是 KMM 不支持。 如果您安裝過 KMM 插件和創(chuàng)建過 KMM 項(xiàng)目,您會(huì)看到 KMM 不管是從 logo 還是項(xiàng)目創(chuàng)建都只有 Android 和 iOS,但是,Kotlin Multiplatform 是支持 Web 的,通過 Kotlin JS。

如果接觸 Kotlin Multiplatform 比較早,那您可能還聽說過 KMP,KN 之類的縮寫,那它們和 KMM 又是什么關(guān)系?簡單來說:

  • KMP 一般指的就是 Kotlin Multiplatform,我依稀記得 KMP 這個(gè)概念是在 Kotlin 1.2 的時(shí)候被提出,可以將 Kotlin 運(yùn)行到特定平臺(tái)的 JVM 和 JS 代碼上
  • KN 一般指的是 Kotlin Native,KN 屬于是將 Kotlin 編譯為 Native 二進(jìn)制文件的技術(shù),甚至可以在沒有虛擬機(jī)的情況下運(yùn)行,例如 KMM 上的 iOS 就是使用了 KN 的能力
  • KMM 是利用了 JVM 和 KN 能力實(shí)現(xiàn)的針對 Android 和 iOS 平臺(tái)的 Kotlin 框架: Android (Kotlin/JVM) 和 iOS (Kotlin/Native)

2832b1d6-82bf-11ed-bfe3-dac502259ad0.png

另外還有 Kotlin JS 用于 Web 平臺(tái),「所以 KMP 可以看作是大集合,而 KMM 是其中針對 Android 和 iOS 的支持,另外通過 Kotlin Native 和 Kotlin JS 也可以支持拓展到 PC 端和 Web 端」。

那么到這里您應(yīng)該理解:「KMM 主要是用來寫跨平臺(tái)邏輯,涉及到 UI 部分您還是需要通過原生實(shí)現(xiàn)」,如果您從另外一個(gè)角度看,用 KMM 對于 Android 開發(fā)來說幾乎等于白送的能力,因?yàn)樗恍枰?Kotlin。
至少 Compose 您還需要適應(yīng)下響應(yīng)式開發(fā)模式。

那或者有人就問:那 KMM 的意義何在? 事實(shí)上還真有,「KMM 在 App 的基建上會(huì)很實(shí)用,比如做數(shù)據(jù)上報(bào),崩潰統(tǒng)計(jì),數(shù)據(jù)分析等等」,純邏輯的跨平臺(tái)不影響 UI 部分,目前也是在這些場景上 KMM 應(yīng)用較多。
另外還有人問我,KMM 可以用 Java 開發(fā)嗎?嗯,這是個(gè)好問題,下次不要再問了。
當(dāng)然,KMM 也存在一些局限,比如使用 ViewModel 和協(xié)程如何在 iOS 上運(yùn)行的問題,不過社區(qū)針對這部分也有一些第三方支持,所以對于 KMM 的未來還是值得期待。

Compose

Compose 相信大家不會(huì)陌生,「其實(shí) Compose 也可以分兩部分看待,Jetpack Compose 和 Compose Multiplatform」:
  • 由 Android 官方維護(hù)的 Jetpack Compose

  • 由 JetBrains 維護(hù)的compose-jb實(shí)現(xiàn)的 Compose Multiplatform

「如果說 KMM 是用于實(shí)現(xiàn)跨平臺(tái)的業(yè)務(wù)邏輯,那么 Compose Multiplatform 就是專注于跨平臺(tái) UI 上的支持」,那 KMM 和 Compose Multiplatform 是什么關(guān)系呢? 從項(xiàng)目角度看,compose-jb 和 KMM 其實(shí)沒有關(guān)系,因?yàn)?KMM 還在 beta,但是 Compose Multiplatform 正式發(fā)布已經(jīng)接近一年的時(shí)間。
但是要說完全沒關(guān)系顯然是不可能,畢竟 Kotlin Native 和 Kotlin JS 的能力其實(shí)在 Compose Multiplatform 里很重要。

當(dāng)然,如下圖所示,Compose Multiplatform 在跨平臺(tái)開發(fā)體驗(yàn)上還是有所區(qū)別,「Compose 目前是通過多個(gè)模塊不同實(shí)現(xiàn)來支持多平臺(tái),所以目前 Jetpack Compose 和 Compose Multiplatform 有一些 "割裂"」,特別是在 Web 端,想要達(dá)到 Flutter 一樣共享代碼的比例還需要繼續(xù)努力。

2845ad40-82bf-11ed-bfe3-dac502259ad0.png ?
PS: 圖比較老,iOS 其實(shí)目前已經(jīng)進(jìn)入實(shí)驗(yàn)階段, androidx.compose.ui.main.defaultUIKitMain 相關(guān)的支持距離正式發(fā)布可以期待。

另外 Compose Multiplatform 還有的問題就是缺少插件社區(qū),這其實(shí)是跨平臺(tái)領(lǐng)域必不可少的配置:「前端有 npm、Flutter 有 pub,您可以通過它們的中央官網(wǎng)搜索您想要的庫,查看它們的熱度,版本,兼容和使用量等等信息,設(shè)置官方認(rèn)證和安全保障,但是 Maven 時(shí)代在這方面一直很弱」。

另一方面 Compose 的優(yōu)勢也很明顯:

  • Kotlin 生態(tài)
  • Android 開發(fā)友好
  • 打包體積增長不大,代碼壓縮比例高
  • 性能不錯(cuò),compose-android 和 compose-desktop 都使用 Skia
「而隨著 Jetpack 開始支持 KMM,那么 Compose Multiplatform 的社區(qū)支持力度將得到進(jìn)一步提升,因?yàn)樽兿?Compose Multiplatform 也可以支持 Jetpack」。 至于前面所說的 "割裂" 問題,目前可以看到官方也在有序推進(jìn),其中就有 desktop 的部分代碼已經(jīng)挪到了androidx 上,從這里看或者統(tǒng)一的 Compose lib 并不遙遠(yuǎn)。288993ac-82bf-11ed-bfe3-dac502259ad0.png
PS: JetBrains 目前就已經(jīng)將 Toolbox 應(yīng)用通過 Compose Multiplatform 實(shí)現(xiàn)并且發(fā)布使用。

Flutter

現(xiàn)在 Flutter 已經(jīng)是 3.3 的版本,F(xiàn)lutter 的特點(diǎn)就是跨平臺(tái),因?yàn)樗]有自己的平臺(tái),同時(shí)它也是 single codebase 的跨平臺(tái)實(shí)現(xiàn)。

291106c0-82bf-11ed-bfe3-dac502259ad0.png ?

關(guān)于 Flutter 和其他框架的對比或者使用數(shù)據(jù)就不多贅述,這里介紹一些其他比較有意思的話題。

1. FlutterVSOther量化對比 2. 國內(nèi)大廠應(yīng)用在移動(dòng)端Flutter框架使用分析 3. 國內(nèi)大廠在移動(dòng)端跨平臺(tái)的框架接入分析

「在 Jetbrains 的開源項(xiàng)目里有一個(gè)叫skiko的項(xiàng)目」,Skiko (Kotlin 的 Skia 的縮寫) 是一個(gè)圖形庫,它支持 Kotlin/JVM、Kotlin/JS、Kotlin/Native 等相關(guān)實(shí)現(xiàn),目前支持有:
  • Kotlin/JVM - Linux、Windows、macOS、Android
  • Kotlin/JS - web
  • Kotlin/Native - iOS 、macOS
如果從這個(gè)角度看 Compose Multiplatform 未來的方向會(huì)和 Flutter 很像,甚至因?yàn)?Flutter 走過更多的坑,所以 Compose Multiplatform 在對接 Skia 上可以有更多的參考。
其實(shí)未來 Linux、Windows 等平臺(tái)也完全可以脫離 JVM 通過 Kotlin/Native + Skiko 實(shí)現(xiàn)支持,只是維護(hù)成本會(huì)變高。

「Flutter 在自建渲染引擎上其實(shí)已經(jīng)越來越激進(jìn),因?yàn)橹苯邮褂?Skia 已經(jīng)無法滿足日益增長的 Bug 和性能極限,所以官方開始了自研渲染引擎 Impeller」 因?yàn)?Flutter 團(tuán)隊(duì)現(xiàn)在出現(xiàn)問題每次都要和 Skia 團(tuán)隊(duì)溝通,然后等跟進(jìn),這樣的節(jié)奏太慢了,從官方的更新日志上就可以看出目前 Flutter 的迭代速度依然很夸張。292120b4-82bf-11ed-bfe3-dac502259ad0.png

所以「這次自研的 Impeller 本質(zhì)上是為了解決 Skia 需要運(yùn)行時(shí)遇到的問題,Impeller 可以直接在編譯器就完成 GLSL 和 MSL,不需要 SKSL 從而提高了性能和運(yùn)行時(shí)的穩(wěn)定性」,目前優(yōu)先在 iOS 平臺(tái)上開始支持,配合 Metal 做優(yōu)化,后續(xù)如果沒問題也會(huì)同步支持 Android 和 Vulkan。

從這個(gè)角度猜測,F(xiàn)lutter 在 Skia 遇到的問題 Compose Multiplatform 也很可能會(huì)遇上,而如果后續(xù) Impeller 項(xiàng)目進(jìn)展順利,那它或者并不會(huì)局限在 Flutter,也許也可以拓展支持到 Compose Multiplatform 上。

其實(shí)自研發(fā)引擎并不奇怪,隨著項(xiàng)目的發(fā)展和深入,很多底層問題沒辦法快速推進(jìn)就會(huì)反推自研,例如Hermes 在 RN 0.7 成為默認(rèn) Engine也是類似問題的體現(xiàn),「自研底層屬于是一個(gè)負(fù)責(zé)任的開源團(tuán)隊(duì)的必經(jīng)之路」。

最后

今天這篇文章的內(nèi)容更多的是科普性質(zhì)而非技術(shù)性,主要是針對目前 KMM、Compose 和 Flutter 的現(xiàn)狀做一個(gè)陳述,其實(shí)很多時(shí)候它們之間并不沖突,但是作為開發(fā)者很經(jīng)常就像開頭一樣,用 "對立" 的角度來看 A 火了 B 就要掛,這種心態(tài)大可不必。


長按右側(cè)二維碼

查看更多開發(fā)者精彩分享

294ce884-82bf-11ed-bfe3-dac502259ad0.png

"開發(fā)者說·DTalk" 面向295fd822-82bf-11ed-bfe3-dac502259ad0.png中國開發(fā)者們征集 Google 移動(dòng)應(yīng)用 (apps & games)?相關(guān)的產(chǎn)品/技術(shù)內(nèi)容。歡迎大家前來分享您對移動(dòng)應(yīng)用的行業(yè)洞察或見解、移動(dòng)開發(fā)過程中的心得或新發(fā)現(xiàn)、以及應(yīng)用出海的實(shí)戰(zhàn)經(jīng)驗(yàn)總結(jié)和相關(guān)產(chǎn)品的使用反饋等。我們由衷地希望可以給這些出眾的中國開發(fā)者們提供更好展現(xiàn)自己、充分發(fā)揮自己特長的平臺(tái)。我們將通過大家的技術(shù)內(nèi)容著重選出優(yōu)秀案例進(jìn)行谷歌開發(fā)技術(shù)專家 (GDE)?的推薦。

2978c33c-82bf-11ed-bfe3-dac502259ad0.gif?點(diǎn)擊屏末||即刻報(bào)名參與 "開發(fā)者說·DTalk"

2987d804-82bf-11ed-bfe3-dac502259ad0.png

299c9cb2-82bf-11ed-bfe3-dac502259ad0.gif

2a27be14-82bf-11ed-bfe3-dac502259ad0.png


原文標(biāo)題:一文快速帶您了解 KMM、Compose 和 Flutter 的現(xiàn)狀 | 開發(fā)者說·DTalk

文章出處:【微信公眾號(hào):谷歌開發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 谷歌
    +關(guān)注

    關(guān)注

    27

    文章

    6128

    瀏覽量

    104948

原文標(biāo)題:一文快速帶您了解 KMM、Compose 和 Flutter 的現(xiàn)狀 | 開發(fā)者說·DTalk

文章出處:【微信號(hào):Google_Developers,微信公眾號(hào):谷歌開發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    鴻蒙Flutter實(shí)戰(zhàn):07混合開發(fā)

    。 其優(yōu)點(diǎn)是主項(xiàng)目開發(fā)者可以不關(guān)注Flutter實(shí)現(xiàn),不需要安裝配置Flutter開發(fā)環(huán)境,缺點(diǎn)是無法及時(shí)修改Flutter代碼,也不存在
    發(fā)表于 10-23 16:00

    Jetpack Compose和設(shè)備類型的三大重要更新

    2024 年 Google I/O 大會(huì)上我們分享了大量更新和公告,幫助開發(fā)者提升工作效率。了解 2024 年 Google I/O 大會(huì)上有關(guān) Jetpack Compose 和設(shè)備類型的三大重要更新。
    的頭像 發(fā)表于 08-09 17:07 ?589次閱讀

    報(bào)名開啟!第二屆OpenHarmony開發(fā)者大會(huì)2024重磅來襲!

    分論壇”為承載,聚焦OpenHarmony 技術(shù)革新,攜手百位技術(shù)專家共同交流開發(fā)者關(guān)心的技術(shù)內(nèi)容,全方位了解最新技術(shù)進(jìn)展。 OpenHarmony開源三年多以來,社區(qū)快速成長,已成為“下
    發(fā)表于 05-14 15:23

    倒計(jì)時(shí)3天!軟通動(dòng)力與相約鯤鵬昇騰開發(fā)者大會(huì)2024

    倒計(jì)時(shí)3天!軟通動(dòng)力與相約鯤鵬昇騰開發(fā)者大會(huì)2024
    的頭像 發(fā)表于 05-07 09:21 ?464次閱讀
    倒計(jì)時(shí)3天!軟通動(dòng)力與<b class='flag-5'>您</b>相約鯤鵬昇騰<b class='flag-5'>開發(fā)者</b>大會(huì)2024

    機(jī)智云開發(fā)者中心:讓移動(dòng)APP應(yīng)用開發(fā)更智能化

    智能化和高效。 ? 新版本開發(fā)者中心的介紹 機(jī)智云物聯(lián)網(wǎng)新版本開發(fā)者中心是款專為開發(fā)者設(shè)計(jì)的一體化開發(fā)工具,旨在提供更智能、簡便的移動(dòng)AP
    的頭像 發(fā)表于 03-26 16:45 ?305次閱讀
    機(jī)智云<b class='flag-5'>開發(fā)者</b>中心:讓移動(dòng)APP應(yīng)用<b class='flag-5'>開發(fā)</b>更智能化

    華為宣布HarmonyOS NEXT鴻蒙星河版開發(fā)者預(yù)覽面向開發(fā)者開放申請

    華為宣布HarmonyOS NEXT鴻蒙星河版開發(fā)者預(yù)覽面向開發(fā)者開放申請,這意味著鴻蒙生態(tài)進(jìn)入第二階段,將加速千行百業(yè)的應(yīng)用鴻蒙化。
    的頭像 發(fā)表于 01-29 16:42 ?1344次閱讀
    華為宣布HarmonyOS NEXT鴻蒙星河版<b class='flag-5'>開發(fā)者</b>預(yù)覽面向<b class='flag-5'>開發(fā)者</b>開放申請

    您有份OpenHarmony開發(fā)者論壇2023年度總結(jié),請查收~

    2023 年 11 月,OpenHarmony 開發(fā)者論壇 1.0 版本正式上線。 感謝各位開發(fā)者對 OpenHarmony 的大力支持和熱愛,成為 OpenHarmony 開發(fā)者論壇的第
    發(fā)表于 01-26 17:27

    HarmonyOS SDK,助力開發(fā)者打造煥然新的鴻蒙原生應(yīng)用

    控件,支持開發(fā)者快速集成滿足規(guī)范要求的登錄按鈕,并提供統(tǒng)的授權(quán)登錄交互 UI,盡可能的簡化 API 調(diào)用次數(shù);地圖選點(diǎn)控件,提供統(tǒng)地點(diǎn)選擇和地點(diǎn)搜索能力,僅需 1 個(gè) API、約
    發(fā)表于 01-19 10:31

    開發(fā)者】HarmonyOS實(shí)踐之應(yīng)用狀態(tài)變量共享

    # 開發(fā)者 # 【開發(fā)者】欄目是為HarmonyOS開發(fā)者提供的展示和分享平臺(tái),在這里,大家可以發(fā)表自己的技術(shù)洞察和見解,也可以展示自己
    的頭像 發(fā)表于 12-26 21:20 ?741次閱讀
    【<b class='flag-5'>開發(fā)者</b><b class='flag-5'>說</b>】HarmonyOS實(shí)踐之應(yīng)用狀態(tài)變量共享

    開發(fā)者開發(fā)案例:使用canvas實(shí)現(xiàn)圖表系列之折線圖

    # 開發(fā)者 # 【開發(fā)者】欄目是為HarmonyOS開發(fā)者提供的展示和分享平臺(tái),在這里,大家可以發(fā)表自己的技術(shù)洞察和見解,也可以展示自己
    的頭像 發(fā)表于 12-13 16:05 ?574次閱讀
    【<b class='flag-5'>開發(fā)者</b><b class='flag-5'>說</b>】<b class='flag-5'>開發(fā)</b>案例:使用canvas實(shí)現(xiàn)圖表系列之折線圖

    歡迎加入飛騰派開發(fā)者社區(qū),感謝每開發(fā)者!

    今年10月,飛騰聯(lián)合電子發(fā)燒友論壇起策劃了飛騰派開發(fā)板測評活動(dòng),受到了廣大開發(fā)者的喜愛。
    的頭像 發(fā)表于 12-11 17:39 ?1336次閱讀
    歡迎加入飛騰派<b class='flag-5'>開發(fā)者</b>社區(qū),感謝每<b class='flag-5'>一</b>位<b class='flag-5'>開發(fā)者</b>!

    歡迎加入飛騰派開發(fā)者社區(qū),感謝每開發(fā)者!

    發(fā)燒友論壇起策劃了飛騰派開發(fā)板測評活動(dòng),受到了廣大開發(fā)者的喜愛。 通過這次活動(dòng),飛騰派成功地吸引了眾多高質(zhì)量開發(fā)者的關(guān)注和參與,進(jìn)步擴(kuò)
    發(fā)表于 12-11 16:11

    開發(fā)者開發(fā)案例分享:萬能卡片也能用來玩游戲

    # 開發(fā)者 # 【開發(fā)者】欄目是為HarmonyOS開發(fā)者提供的展示和分享平臺(tái),在這里,大家可以發(fā)表自己的技術(shù)洞察和見解,也可以展示自己
    的頭像 發(fā)表于 11-30 21:15 ?480次閱讀
    【<b class='flag-5'>開發(fā)者</b><b class='flag-5'>說</b>】<b class='flag-5'>開發(fā)</b>案例分享:萬能卡片也能用來玩游戲

    HarmonyOS NEXT讓開發(fā)者快速上手媒體生態(tài)致體驗(yàn)開發(fā)

    系統(tǒng)相機(jī)的效果好?”,“為什么我的應(yīng)用和其他的音樂起發(fā)聲了,我要怎么處理” 以及“我應(yīng)該怎么做才能在系統(tǒng)的播控中心里可以看到?”等問題。對于開發(fā)者的這些疑問,HarmonyOS NEXT通過提供簡單易用體驗(yàn)致的生態(tài)借口,就
    的頭像 發(fā)表于 11-22 16:20 ?620次閱讀
    HarmonyOS NEXT讓<b class='flag-5'>開發(fā)者</b><b class='flag-5'>快速</b>上手媒體生態(tài)<b class='flag-5'>一</b>致體驗(yàn)<b class='flag-5'>開發(fā)</b>

    社區(qū)|開拓全球視野,賦能更高效的全球化應(yīng)用開發(fā)

    在這個(gè)不斷進(jìn)步的數(shù)字化時(shí)代,創(chuàng)新和突破是每開發(fā)者的追求。而應(yīng)用的全球化,則是開發(fā)者們面臨的重要挑戰(zhàn)和機(jī)遇。Flutter 作為跨平臺(tái)的前沿 UI 框架,提供了高效的解決方案,幫助
    的頭像 發(fā)表于 11-21 17:45 ?343次閱讀
    社區(qū)<b class='flag-5'>說</b>|開拓全球視野,賦能更高效的全球化應(yīng)用<b class='flag-5'>開發(fā)</b>