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

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

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

Jetpack Compose助力Play商店實現(xiàn)進一步的優(yōu)化

谷歌開發(fā)者 ? 來源:Android 開發(fā)者 ? 作者:Android 開發(fā)者 ? 2022-04-02 13:38 ? 次閱讀

作者 / Google Play 技術(shù)負(fù)責(zé)人 Andrew Flynn 和 Jon Boekenoogen

2020 年,Google Play 商店開發(fā)團隊管理層做出了一個重大決定: 改造整個 Play 商店技術(shù)棧。因為現(xiàn)有代碼的歷史已經(jīng)長達 10 多年,在無數(shù)的 Android 平臺版本發(fā)布和功能更新的過程中產(chǎn)生了巨大的技術(shù)負(fù)債。我們需要新的框架,在不影響開發(fā)者的工作效率、用戶體驗或 Play 商店自身性能的同時,能夠支撐數(shù)百名工程師同時開展工作。

我們?yōu)榇酥贫艘粋€長期路線圖,來更新商店內(nèi)從網(wǎng)絡(luò)層一直到像素渲染的所有內(nèi)容。在這之中,我們還想要采用現(xiàn)代的聲明式界面框架,以實現(xiàn)我們圍繞交互性和用戶滿意度的產(chǎn)品目標(biāo)。在分析了各種選擇后,我們做出了 (在當(dāng)時) 一個大膽的決定——使用當(dāng)時還處于 Alpha 預(yù)覽階段的 Jetpack Compose。

從那時起,Google Play 商店與 Jetpack Compose 團隊密切合作,發(fā)布并完善了滿足我們特定需求的 Jetpack Compose 版本。本文將為您介紹我們的遷移方法以及在此過程中發(fā)現(xiàn)的挑戰(zhàn)和優(yōu)勢,并分享一些對于有眾多貢獻者的應(yīng)用選擇 Compose 的洞察。

優(yōu)先考慮

當(dāng)我們對新的界面渲染層使用 Jetpack Compose 時,需要優(yōu)先考慮以下兩點:

開發(fā)者的工作效率: Play 商店團隊有數(shù)百個工程師改進代碼,因此開發(fā)起來應(yīng)該很容易 (也很有趣)。

性能: Play 商店會渲染大量媒體密集型內(nèi)容,其中很多業(yè)務(wù)指標(biāo)對延遲和卡頓十分敏感,所以我們需要確保它在所有設(shè)備上表現(xiàn)良好,尤其是低內(nèi)存硬件和 Android (Go 版本) 設(shè)備。

開發(fā)者的工作效率

一年多來,我們一直在使用 Jetpack Compose 編寫用戶界面代碼,也得益于 Jetpack Compose 讓界面開發(fā)變得更加簡單。

我們傾向于編寫界面時使用更少的代碼,有時甚至可以減少 50%。此項改進的實現(xiàn)得益于 Compose 是一個利用了 Kotlin 簡潔性的聲明式界面框架。自定義繪圖和布局現(xiàn)在是簡單的函數(shù)調(diào)用,而不用再通過對視圖子類進行各種復(fù)寫。

以評分表格為例:

使用視圖類編寫,此表格包含:

總共 3 個視圖類,其中 2 個需要自定義繪制圓角矩形和星形

約 350 行 Java 代碼,55 行 XML

使用 Compose 編寫,此表格包含:

所有的 @Composable 函數(shù)都包含在同一文件和語言中!

約 210 行 Kotlin 代碼

動畫因其簡單、富有表現(xiàn)力

而成為 Compose 備受贊譽的一項功能。我們的團隊正在使用 Compose 構(gòu)建動效功能,極大地提高了 Play 商店用戶的滿意度。借助 Compose 的聲明性和動畫 API,編寫連續(xù)或并行動畫從未如此簡單。我們的團隊不再擔(dān)心關(guān)于動畫取消和回調(diào)鏈的所有極端情況。Lottie 是一個流行的動畫庫,已經(jīng)提供了易于使用的 Compose API。

現(xiàn)在您可能會想: 這一切聽起來都很棒,但提供視圖的庫依賴項呢?確實,并非所有的庫開發(fā)者都實現(xiàn)了基于 Compose 的 API,尤其是在我們首次遷移時。但是,Compose 通過其 ComposeView 和 AndroidView API 提供了簡單的視圖互操作性。我們以這種方式成功地與 ExoPlayer 和 YouTube Player 等流行庫集成。

性能Play 商店和 Jetpack Compose 團隊密切合作,以確保 Compose 可以像視圖框架一樣快速運行并且沒有卡頓。由于需要把 Compose 打包在應(yīng)用中 (而不是作為 Android 框架的一部分),這是一項艱巨的任務(wù)。在屏幕上渲染單個界面組件很快,但是將整個 Compose 框架加載到應(yīng)用內(nèi)存中所用的端到端時間卻很長。

Play 商店采用 Compose 后最大的性能改進之一來自基準(zhǔn)配置文件的開發(fā)。雖然已經(jīng)推出了一段時間的云配置文件可以幫助改善應(yīng)用啟動時間,但是它們只適用于 API 28+,且對于更新節(jié)奏頻繁 (每周) 的應(yīng)用效果不佳。為了解決這一問題,Play 商店和 Android 團隊合作開發(fā)了基準(zhǔn)配置文件 (Baseline Profiles): 開發(fā)者預(yù)定義打包好的、應(yīng)用可以指定的一個配置文件,它們隨您的應(yīng)用提供,與云配置文件完全兼容,并且可以在具體應(yīng)用級別和庫級別進行定義 (適配 Compose 的開發(fā)者可免費使用此功能!)。通過推出基準(zhǔn)配置文件,Play 商店發(fā)現(xiàn)其搜索結(jié)果頁的初始頁面渲染時間減少了 40%。這是巨大的進步!

重復(fù)使用界面組件是使 Compose 在渲染方面表現(xiàn)出色的核心機制,尤其是在滾動情況下。Compose 會盡可能跳過已知可以跳過的可組合項的重組 (例如,它們是不可變的),但是如果所有參數(shù)滿足 @Stable 注釋要求,開發(fā)者也可以強制將可組合項設(shè)置為可跳過。Compose 編譯器還提供了一份便捷指南,說明防止特定函數(shù)被跳過的原理。當(dāng)在 Play 商店中創(chuàng)建在滾動情況下頻繁使用的大量重復(fù)使用界面組件時,我們發(fā)現(xiàn)不必要的重組會增加丟失的幀時間,從而導(dǎo)致卡頓。我們建立了一個修飾符 (Modifier),以便在我們的調(diào)試設(shè)置中輕松發(fā)現(xiàn)這些重組。通過將這些技術(shù)應(yīng)用于我們的界面組件,我們能夠?qū)⒖D減少 10-15%。

為 Play 商店應(yīng)用優(yōu)化 Compose 的另一個關(guān)鍵是為整個應(yīng)用制定詳細(xì)的端到端的遷移策略。在最初的集成實驗中,我們遇到了雙棧問題: 在單個用戶會話中同時運行 Compose 和視圖類渲染非常占用內(nèi)存,尤其是在低端設(shè)備上。當(dāng)代碼在同一頁面上運行時就會出現(xiàn)這種情況,當(dāng)兩個不同的頁面 (例如,Play 商店主頁和搜索結(jié)果頁) 各自位于不同的堆棧上時,也會出現(xiàn)這種情況。為了改善這種啟動延遲,我們?yōu)轫撁孢w移到 Compose 的順序和時間安排制定一個具體計劃,這是非常重要的。同時我們發(fā)現(xiàn),在應(yīng)用遷移到完全使用 Compose 進行渲染使用之前,對一些通用類進行一定的 "預(yù)熱" 是有助于提高內(nèi)存性能的。

將 Compose 從 Android 框架中分離出來減少了我們團隊直接為 Jetpack Compose 做出貢獻的開銷,從而縮短了改進工作的周轉(zhuǎn)時間,使所有開發(fā)者受益。我們與 Jetpack Compose 團隊合作,推出 LazyList 項目類型緩存等功能,并快速進行輕量級修復(fù),如額外的對象分配。

展望未來

Play 商店采用 Compose 后,提升了我們團隊開發(fā)者的幸福感,并大大提高了代碼質(zhì)量和健康度。所有的全新 Play 商店功能都建立在此框架之上,且 Compose 有助于為應(yīng)用實現(xiàn)更快的速度和更順暢的訪問。由于我們 Compose 遷移策略的性質(zhì),我們無法準(zhǔn)確衡量 APK 大小變化或構(gòu)建速度等,但是我們看到的所有跡象都非常積極!

Compose 是 Android 界面開發(fā)的未來,也幫助 Play 商店實現(xiàn)了進一步的優(yōu)化。歡迎您持續(xù)關(guān)注我們了解最新內(nèi)容。

原文標(biāo)題:使用 Jetpack Compose 提升 Play 商店的用戶體驗

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

審核編輯:湯梓紅

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

    關(guān)注

    12

    文章

    3908

    瀏覽量

    126913
  • Google
    +關(guān)注

    關(guān)注

    5

    文章

    1752

    瀏覽量

    57327
  • 設(shè)備
    +關(guān)注

    關(guān)注

    2

    文章

    4416

    瀏覽量

    70452

原文標(biāo)題:使用 Jetpack Compose 提升 Play 商店的用戶體驗

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

收藏 人收藏

    評論

    相關(guān)推薦

    英特爾將進一步分離芯片制造和設(shè)計業(yè)務(wù)

    面對公司成立50年來最為嚴(yán)峻的挑戰(zhàn),英特爾宣布了項重大戰(zhàn)略調(diào)整,旨在通過進一步分離芯片制造與設(shè)計業(yè)務(wù),重塑競爭力。這決策標(biāo)志著英特爾在應(yīng)對行業(yè)變革中的堅定步伐。
    的頭像 發(fā)表于 09-19 16:48 ?213次閱讀

    通過展頻進一步優(yōu)化EMI

    電子發(fā)燒友網(wǎng)站提供《通過展頻進一步優(yōu)化EMI.pdf》資料免費下載
    發(fā)表于 09-04 09:32 ?0次下載
    通過展頻<b class='flag-5'>進一步</b><b class='flag-5'>優(yōu)化</b>EMI

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

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

    Melexis推出全新MLX81123芯片,進一步擴展LIN RGB系列產(chǎn)品線

    Melexis近日宣布,作為汽車動態(tài)照明LED驅(qū)動芯片領(lǐng)域的領(lǐng)軍者,正式推出全新產(chǎn)品MLX81123,進一步擴展LIN RGB系列產(chǎn)品線。這款芯片在前代產(chǎn)品的基礎(chǔ)上進行深度優(yōu)化,封裝設(shè)計更為緊湊
    的頭像 發(fā)表于 06-14 14:41 ?588次閱讀

    西門子與微軟進一步擴展戰(zhàn)略合作關(guān)系

    近日,西門子數(shù)字化工業(yè)軟件與微軟宣布進一步擴展雙方的戰(zhàn)略合作關(guān)系。通過微軟Azure云服務(wù),西門子正式推出Xcelerator as a Service工業(yè)軟件解決方案,為客戶提供更靈活、高效的服務(wù)體驗。
    的頭像 發(fā)表于 05-21 10:47 ?603次閱讀

    進一步解讀英偉達 Blackwell 架構(gòu)、NVlink及GB200 超級芯片

    和縮減協(xié)議(SHARP)?引擎,優(yōu)化網(wǎng)絡(luò)內(nèi)縮減和多播加速,進一步提高通信效率。 NVLink Switch 允許 NVLink 連接跨節(jié)點擴展,形成高帶寬、多節(jié)點GPU集群,實際上創(chuàng)建了數(shù)據(jù)中心級
    發(fā)表于 05-13 17:16

    Cognizant 將延續(xù)與 Pon IT 的合作,旨在進一步管理和優(yōu)化云服務(wù)

    得以繼續(xù)為 Pon IT 旗下各家運營公司提供云平臺托管服務(wù)。在下階段的合作中,Cognizant 將繼續(xù)實施進一步優(yōu)化措施,旨在使 Pon IT 從
    的頭像 發(fā)表于 03-27 22:49 ?268次閱讀

    Arbe在中國上海設(shè)立分公司,進一步增強企業(yè)影響力

    摘要:中國團隊將進一步促進Arbe與中國市場重要企業(yè)之間的緊密合作。 新代4D成像雷達解決方案的頭部企業(yè)Arbe Robotics(納斯達克股票代碼:ARBE;以下稱Arbe)近日宣布已在上海設(shè)立
    的頭像 發(fā)表于 03-25 09:44 ?362次閱讀

    隆基攜手DAT Group與SPower進一步加速越南高效能量綠色轉(zhuǎn)型

    2月26日,隆基與DAT Group及 SPower 在胡志明市簽署了45MW Hi-MO 7供貨訂單,此次合作將進一步加速越南能源結(jié)構(gòu)向綠色和可持續(xù)方向轉(zhuǎn)變,有力支持越南2050年前實現(xiàn)凈零碳目標(biāo)。
    的頭像 發(fā)表于 03-07 10:31 ?340次閱讀

    英飛凌重組銷售與營銷組織,進一步提升以客戶為中心的服務(wù)及領(lǐng)先的應(yīng)用支持能力

    【 2024 年 2 月 28 日,德國慕尼黑訊】 為實現(xiàn)有雄心的增長目標(biāo),英飛凌科技股份公司(FSE代碼:IFX / OTCQX代碼:IFNNY)正進一步強化其銷售組織。自3月1日起,英飛凌的銷售
    發(fā)表于 03-01 16:31 ?365次閱讀
      英飛凌重組銷售與營銷組織,<b class='flag-5'>進一步</b>提升以客戶為中心的服務(wù)及領(lǐng)先的應(yīng)用支持能力

    材料價格進一步下降,盈利觸底 鋰電材料企業(yè)如何應(yīng)對?

    在上游原料價格相對穩(wěn)定、終端銷量有所好轉(zhuǎn)的情況下,季度四大鋰電主材價格卻出現(xiàn)進一步下跌。
    的頭像 發(fā)表于 03-01 10:25 ?844次閱讀

    MediaTek宣布將進一步深化與海信的長期合作關(guān)系

    MediaTek 宣布將進一步深化與海信的長期合作關(guān)系。海信率先采用了 MediaTek Pentonic 智能電視芯片,顯著提升了流媒體內(nèi)容的畫質(zhì)表現(xiàn)。自 2024 年起,MediaTek AI 超級分辨率技術(shù)(AI-SR)將應(yīng)用于海信全系列智能電視產(chǎn)品。
    的頭像 發(fā)表于 01-12 09:37 ?726次閱讀

    有什么方法可以進一步提高AD7714的分辨率啊?

    級放大再加給AD7714時,測得人分辨率還要低些。由于是用干電池得到AD7714的輸入信號,該信號相對來說很穩(wěn)定,而且板上的噪聲也不是太大。請問各位大蝦,還有什么方法可以進一步提高AD7714的分辨率?。坎粍俑屑?!
    發(fā)表于 12-25 06:33

    借助人工智能,存儲器比重將進一步增加

    SK海力士預(yù)測在人工智能(AI)領(lǐng)域,存儲器解決方案的比重將進一步增加,可以通過類似AiMX的解決方案部分替代圖形處理單元(GPU)。
    發(fā)表于 12-04 09:52 ?358次閱讀
    借助人工智能,存儲器比重將<b class='flag-5'>進一步</b>增加

    ad9106如何將波形頻率設(shè)置為進一步降低到10Hz?

    你好,我有個小問題。我使用100m時鐘芯片。每個時鐘只有10ns,ad9106寄存器的最小輸出波形只有100Hz。如何將波形頻率設(shè)置為進一步降低到10Hz?我已將配置設(shè)置為相關(guān)寄存器的最大值。拍
    發(fā)表于 12-01 06:12