作者 / Google Play 技術(shù)負(fù)責(zé)人 Andrew Flynn 和 Jon Boekenoogen
2020 年,Google Play 商店開(kāi)發(fā)團(tuán)隊(duì)管理層做出了一個(gè)重大決定: 改造整個(gè) Play 商店技術(shù)棧。因?yàn)楝F(xiàn)有代碼的歷史已經(jīng)長(zhǎng)達(dá) 10 多年,在無(wú)數(shù)的 Android 平臺(tái)版本發(fā)布和功能更新的過(guò)程中產(chǎn)生了巨大的技術(shù)負(fù)債。我們需要新的框架,在不影響開(kāi)發(fā)者的工作效率、用戶(hù)體驗(yàn)或 Play 商店自身性能的同時(shí),能夠支撐數(shù)百名工程師同時(shí)開(kāi)展工作。
我們?yōu)榇酥贫艘粋€(gè)長(zhǎng)期路線(xiàn)圖,來(lái)更新商店內(nèi)從網(wǎng)絡(luò)層一直到像素渲染的所有內(nèi)容。在這之中,我們還想要采用現(xiàn)代的聲明式界面框架,以實(shí)現(xiàn)我們圍繞交互性和用戶(hù)滿(mǎn)意度的產(chǎn)品目標(biāo)。在分析了各種選擇后,我們做出了 (在當(dāng)時(shí)) 一個(gè)大膽的決定——使用當(dāng)時(shí)還處于 Alpha 預(yù)覽階段的 Jetpack Compose。
從那時(shí)起,Google Play 商店與 Jetpack Compose 團(tuán)隊(duì)密切合作,發(fā)布并完善了滿(mǎn)足我們特定需求的 Jetpack Compose 版本。本文將為您介紹我們的遷移方法以及在此過(guò)程中發(fā)現(xiàn)的挑戰(zhàn)和優(yōu)勢(shì),并分享一些對(duì)于有眾多貢獻(xiàn)者的應(yīng)用選擇 Compose 的洞察。
優(yōu)先考慮
當(dāng)我們對(duì)新的界面渲染層使用 Jetpack Compose 時(shí),需要優(yōu)先考慮以下兩點(diǎn):
開(kāi)發(fā)者的工作效率: Play 商店團(tuán)隊(duì)有數(shù)百個(gè)工程師改進(jìn)代碼,因此開(kāi)發(fā)起來(lái)應(yīng)該很容易 (也很有趣)。
性能: Play 商店會(huì)渲染大量媒體密集型內(nèi)容,其中很多業(yè)務(wù)指標(biāo)對(duì)延遲和卡頓十分敏感,所以我們需要確保它在所有設(shè)備上表現(xiàn)良好,尤其是低內(nèi)存硬件和 Android (Go 版本) 設(shè)備。
開(kāi)發(fā)者的工作效率
一年多來(lái),我們一直在使用 Jetpack Compose 編寫(xiě)用戶(hù)界面代碼,也得益于 Jetpack Compose 讓界面開(kāi)發(fā)變得更加簡(jiǎn)單。
我們傾向于編寫(xiě)界面時(shí)使用更少的代碼,有時(shí)甚至可以減少 50%。此項(xiàng)改進(jìn)的實(shí)現(xiàn)得益于 Compose 是一個(gè)利用了 Kotlin 簡(jiǎn)潔性的聲明式界面框架。自定義繪圖和布局現(xiàn)在是簡(jiǎn)單的函數(shù)調(diào)用,而不用再通過(guò)對(duì)視圖子類(lèi)進(jìn)行各種復(fù)寫(xiě)。
以評(píng)分表格為例:
使用視圖類(lèi)編寫(xiě),此表格包含:
總共 3 個(gè)視圖類(lèi),其中 2 個(gè)需要自定義繪制圓角矩形和星形
約 350 行 Java 代碼,55 行 XML
使用 Compose 編寫(xiě),此表格包含:
所有的 @Composable 函數(shù)都包含在同一文件和語(yǔ)言中!
約 210 行 Kotlin 代碼
動(dòng)畫(huà)因其簡(jiǎn)單、富有表現(xiàn)力
而成為 Compose 備受贊譽(yù)的一項(xiàng)功能。我們的團(tuán)隊(duì)正在使用 Compose 構(gòu)建動(dòng)效功能,極大地提高了 Play 商店用戶(hù)的滿(mǎn)意度。借助 Compose 的聲明性和動(dòng)畫(huà) API,編寫(xiě)連續(xù)或并行動(dòng)畫(huà)從未如此簡(jiǎn)單。我們的團(tuán)隊(duì)不再擔(dān)心關(guān)于動(dòng)畫(huà)取消和回調(diào)鏈的所有極端情況。Lottie 是一個(gè)流行的動(dòng)畫(huà)庫(kù),已經(jīng)提供了易于使用的 Compose API。
現(xiàn)在您可能會(huì)想: 這一切聽(tīng)起來(lái)都很棒,但提供視圖的庫(kù)依賴(lài)項(xiàng)呢?確實(shí),并非所有的庫(kù)開(kāi)發(fā)者都實(shí)現(xiàn)了基于 Compose 的 API,尤其是在我們首次遷移時(shí)。但是,Compose 通過(guò)其 ComposeView 和 AndroidView API 提供了簡(jiǎn)單的視圖互操作性。我們以這種方式成功地與 ExoPlayer 和 YouTube Player 等流行庫(kù)集成。
性能Play 商店和 Jetpack Compose 團(tuán)隊(duì)密切合作,以確保 Compose 可以像視圖框架一樣快速運(yùn)行并且沒(méi)有卡頓。由于需要把 Compose 打包在應(yīng)用中 (而不是作為 Android 框架的一部分),這是一項(xiàng)艱巨的任務(wù)。在屏幕上渲染單個(gè)界面組件很快,但是將整個(gè) Compose 框架加載到應(yīng)用內(nèi)存中所用的端到端時(shí)間卻很長(zhǎng)。
Play 商店采用 Compose 后最大的性能改進(jìn)之一來(lái)自基準(zhǔn)配置文件的開(kāi)發(fā)。雖然已經(jīng)推出了一段時(shí)間的云配置文件可以幫助改善應(yīng)用啟動(dòng)時(shí)間,但是它們只適用于 API 28+,且對(duì)于更新節(jié)奏頻繁 (每周) 的應(yīng)用效果不佳。為了解決這一問(wèn)題,Play 商店和 Android 團(tuán)隊(duì)合作開(kāi)發(fā)了基準(zhǔn)配置文件 (Baseline Profiles): 開(kāi)發(fā)者預(yù)定義打包好的、應(yīng)用可以指定的一個(gè)配置文件,它們隨您的應(yīng)用提供,與云配置文件完全兼容,并且可以在具體應(yīng)用級(jí)別和庫(kù)級(jí)別進(jìn)行定義 (適配 Compose 的開(kāi)發(fā)者可免費(fèi)使用此功能!)。通過(guò)推出基準(zhǔn)配置文件,Play 商店發(fā)現(xiàn)其搜索結(jié)果頁(yè)的初始頁(yè)面渲染時(shí)間減少了 40%。這是巨大的進(jìn)步!
重復(fù)使用界面組件是使 Compose 在渲染方面表現(xiàn)出色的核心機(jī)制,尤其是在滾動(dòng)情況下。Compose 會(huì)盡可能跳過(guò)已知可以跳過(guò)的可組合項(xiàng)的重組 (例如,它們是不可變的),但是如果所有參數(shù)滿(mǎn)足 @Stable 注釋要求,開(kāi)發(fā)者也可以強(qiáng)制將可組合項(xiàng)設(shè)置為可跳過(guò)。Compose 編譯器還提供了一份便捷指南,說(shuō)明防止特定函數(shù)被跳過(guò)的原理。當(dāng)在 Play 商店中創(chuàng)建在滾動(dòng)情況下頻繁使用的大量重復(fù)使用界面組件時(shí),我們發(fā)現(xiàn)不必要的重組會(huì)增加丟失的幀時(shí)間,從而導(dǎo)致卡頓。我們建立了一個(gè)修飾符 (Modifier),以便在我們的調(diào)試設(shè)置中輕松發(fā)現(xiàn)這些重組。通過(guò)將這些技術(shù)應(yīng)用于我們的界面組件,我們能夠?qū)⒖D減少 10-15%。
為 Play 商店應(yīng)用優(yōu)化 Compose 的另一個(gè)關(guān)鍵是為整個(gè)應(yīng)用制定詳細(xì)的端到端的遷移策略。在最初的集成實(shí)驗(yàn)中,我們遇到了雙棧問(wèn)題: 在單個(gè)用戶(hù)會(huì)話(huà)中同時(shí)運(yùn)行 Compose 和視圖類(lèi)渲染非常占用內(nèi)存,尤其是在低端設(shè)備上。當(dāng)代碼在同一頁(yè)面上運(yùn)行時(shí)就會(huì)出現(xiàn)這種情況,當(dāng)兩個(gè)不同的頁(yè)面 (例如,Play 商店主頁(yè)和搜索結(jié)果頁(yè)) 各自位于不同的堆棧上時(shí),也會(huì)出現(xiàn)這種情況。為了改善這種啟動(dòng)延遲,我們?yōu)轫?yè)面遷移到 Compose 的順序和時(shí)間安排制定一個(gè)具體計(jì)劃,這是非常重要的。同時(shí)我們發(fā)現(xiàn),在應(yīng)用遷移到完全使用 Compose 進(jìn)行渲染使用之前,對(duì)一些通用類(lèi)進(jìn)行一定的 "預(yù)熱" 是有助于提高內(nèi)存性能的。
將 Compose 從 Android 框架中分離出來(lái)減少了我們團(tuán)隊(duì)直接為 Jetpack Compose 做出貢獻(xiàn)的開(kāi)銷(xiāo),從而縮短了改進(jìn)工作的周轉(zhuǎn)時(shí)間,使所有開(kāi)發(fā)者受益。我們與 Jetpack Compose 團(tuán)隊(duì)合作,推出 LazyList 項(xiàng)目類(lèi)型緩存等功能,并快速進(jìn)行輕量級(jí)修復(fù),如額外的對(duì)象分配。
展望未來(lái)
Play 商店采用 Compose 后,提升了我們團(tuán)隊(duì)開(kāi)發(fā)者的幸福感,并大大提高了代碼質(zhì)量和健康度。所有的全新 Play 商店功能都建立在此框架之上,且 Compose 有助于為應(yīng)用實(shí)現(xiàn)更快的速度和更順暢的訪(fǎng)問(wèn)。由于我們 Compose 遷移策略的性質(zhì),我們無(wú)法準(zhǔn)確衡量 APK 大小變化或構(gòu)建速度等,但是我們看到的所有跡象都非常積極!
Compose 是 Android 界面開(kāi)發(fā)的未來(lái),也幫助 Play 商店實(shí)現(xiàn)了進(jìn)一步的優(yōu)化。歡迎您持續(xù)關(guān)注我們了解最新內(nèi)容。
原文標(biāo)題:使用 Jetpack Compose 提升 Play 商店的用戶(hù)體驗(yàn)
文章出處:【微信公眾號(hào):谷歌開(kāi)發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
審核編輯:湯梓紅
-
Android
+關(guān)注
關(guān)注
12文章
3941瀏覽量
127709 -
Google
+關(guān)注
關(guān)注
5文章
1770瀏覽量
57696 -
設(shè)備
+關(guān)注
關(guān)注
2文章
4536瀏覽量
70788
原文標(biāo)題:使用 Jetpack Compose 提升 Play 商店的用戶(hù)體驗(yàn)
文章出處:【微信號(hào):Google_Developers,微信公眾號(hào):谷歌開(kāi)發(fā)者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論