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

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

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

基準(zhǔn)配置文件將應(yīng)用啟動時間縮短最高40%

谷歌開發(fā)者 ? 來源:谷歌開發(fā)者 ? 作者:谷歌開發(fā)者 ? 2022-03-11 09:46 ? 次閱讀

啟動時間的重要性

應(yīng)用性能和用戶參與度的相關(guān)性在許多應(yīng)用中都有所體現(xiàn)。用戶希望應(yīng)用響應(yīng)迅速且能快速加載,而啟動時間就是衡量應(yīng)用性能和質(zhì)量的主要指標(biāo)之一。

我們的一些合作伙伴已經(jīng)投入大量時間和資源來優(yōu)化應(yīng)用啟動情況。例如,您可以閱讀了解 Facebook 的優(yōu)化歷程。

本文我們將討論基準(zhǔn)配置文件和其改善應(yīng)用和開發(fā)庫性能的方式,包括它們?nèi)绾螌訒r間縮短了最高 40%。雖然本文側(cè)重于應(yīng)用啟動,但是基準(zhǔn)配置文件也可以極大改善卡頓情況。

回顧

Android 9 (API 級別 28) 在 Play Cloud 中引入了 ART 優(yōu)化配置文件,以縮短應(yīng)用啟動時間。在云配置文件可用時,我們看到應(yīng)用的冷啟動在不同設(shè)備上平均快了至少 15%。

配置文件的工作原理

當(dāng)應(yīng)用在安裝或更新后首次啟動時,它的代碼以解釋模式運行,直到被 JIT。由于存儲和加載完全編譯的應(yīng)用所需的開銷較大,自 Android 6 開始,Java 和 Kotlin 代碼在 APK 中編譯為 dex 字節(jié)碼,而不是完全編譯為機器代碼。應(yīng)用中經(jīng)常被使用以及用于應(yīng)用啟動的類和方法,都會被寫入配置文件。一旦設(shè)備進(jìn)入閑置模式,ART 就基于這些配置文件編譯應(yīng)用,以加快后續(xù)的應(yīng)用啟動。

從 Android 9 (API 級別 28) 開始,Google Play 也會提供云配置文件。當(dāng)應(yīng)用在設(shè)備上運行時,ART 生成的配置文件由 Play 商店應(yīng)用上傳并在云端聚合。為應(yīng)用上傳了足夠的配置文件后,Play 應(yīng)用將使用聚合的配置文件來進(jìn)行后續(xù)的安裝。

存在的問題

雖然云配置文件在可用時很有幫助,但并非總是在應(yīng)用安裝后即可使用。收集和聚合配置文件通常要幾天時間,而許多應(yīng)用會每周更新,這就是問題所在。而且許多用戶會在云配置文件可用之前安裝更新。Google Android 團隊開始尋找其他方法來改善配置文件延遲。

解決方案

基準(zhǔn)配置文件是提供配置文件的一個全新機制,可在 Android 7 (API 級別 24) 和更高版本上使用?;鶞?zhǔn)配置文件是由 Android Gradle 插件生成的 ART 配置文件,使用可由應(yīng)用和庫提供的人類可讀懂的配置文件格式。示例如下:?

HSPLandroidx/compose/runtime/ComposerImpl;->updateValue(Ljava/lang/Object;)VHSPLandroidx/compose/runtime/ComposerImpl;->updatedNodeCount(I)IHLandroidx/compose/runtime/ComposerImpl;->validateNodeExpected()VPLandroidx/compose/runtime/CompositionImpl;->applyChanges()VHLandroidx/compose/runtime/ComposerKt;->findLocation(Ljava/util/List;I)I

二進(jìn)制文件存儲在 APK 資源目錄中的特定位置 (assets/dexopt/baseline.prof)。

基準(zhǔn)配置文件在構(gòu)建時創(chuàng)建,作為 APK 的一部分發(fā)送到 Play 中,然后在下載應(yīng)用時,從 Play 發(fā)送至用戶。基準(zhǔn)配置文件在云配置文件尚不可用時,填補了 ART 云配置文件流水線中的空白,在云配置文件可用時,則會自動與其合并?;鶞?zhǔn)配置文件最大的優(yōu)勢之一是可以在本地開發(fā)和評估,這樣開發(fā)者可以看到真實的最終用戶性能改進(jìn)情況。它們還支持較低的 Android 版本 (7 和更高版本),而云配置文件只在 Android 9 及以上版本中提供。

影響

應(yīng)用開發(fā)者

2021 年初,Google 地圖的發(fā)布周期從兩周改為一周。更頻繁的更新意味著更頻繁地舍棄本地預(yù)編譯,以及更多用戶在沒有 Play Cloud 配置文件的情況下,遇到啟動緩慢的情況。通過使用基準(zhǔn)配置文件,Google 地圖將平均啟動時間縮短了 30%,搜索速度相應(yīng)增長了 2.4%,對于這樣一個成熟的應(yīng)用來說,這是巨大的性能改進(jìn)。

庫開發(fā)者

庫中的代碼與應(yīng)用中的代碼類似,默認(rèn)都不是完全編譯,如果它在啟動的關(guān)鍵路徑中發(fā)揮重要作用,則可能存在問題。

Jetpack Compose 是一個不屬于 Android 系統(tǒng)映像的界面庫,因此與大多數(shù) Android 視圖工具包代碼不同,它在安裝時并未完全編譯。這導(dǎo)致了性能問題,尤其是在應(yīng)用前幾次冷啟動時。

為解決這一問題,Compose 使用了配置文件安裝程序。該程序附帶了基準(zhǔn)配置文件規(guī)則,可以縮短 Compose 應(yīng)用的啟動時間并減少卡頓。

Google Play 商店的搜索結(jié)果頁已經(jīng)使用 Compose 進(jìn)行重寫。在集成 Compose 的基準(zhǔn)配置文件規(guī)則后,渲染初始搜索結(jié)果頁 (包括圖像) 的時間縮短了約 40%。

Android 團隊還將基準(zhǔn)配置文件添加到了相關(guān)的 AndroidX 庫。這可讓所有使用這些庫的 Android 應(yīng)用受益。ConstraintLayout 發(fā)現(xiàn)附帶的配置文件規(guī)則將動畫幀時間縮短了超過 1 毫秒。

如何使用基準(zhǔn)配置文件

創(chuàng)建自定義基準(zhǔn)配置文件

所有應(yīng)用和庫開發(fā)者都可以從添加基準(zhǔn)配置文件中獲益。理想狀態(tài)下,開發(fā)者為最關(guān)鍵的用戶旅程創(chuàng)建配置文件,來確保不管云配置文件是否可用,這些旅程都擁有始終快速的性能。您可以查看詳細(xì)指南,了解如何為應(yīng)用和庫開發(fā)者設(shè)置基準(zhǔn)配置文件。

更新依賴項

如果您還未準(zhǔn)備好為應(yīng)用生成基準(zhǔn)配置文件,您仍然可以受益于更新依賴項。如果您使用 Android Gradle 插件 7.1.0-alpha05 或更高版本構(gòu)建應(yīng)用,您將獲得包含在 APK 中的基準(zhǔn)配置文件,這些配置文件已經(jīng)由庫 (例如 Jetpack) 提供。Google Play 在安裝時借助這些配置文件編譯應(yīng)用。您可以將這些配置文件作為構(gòu)建應(yīng)用的補充部分。

衡量改進(jìn)情況

不要忘記衡量應(yīng)用改進(jìn)情況。您可以按照步驟操作,了解如何在本地衡量使用生成的配置文件的啟動情況,也歡迎您持續(xù)關(guān)注我們了解更多最新內(nèi)容。

原文標(biāo)題:通過基準(zhǔn)配置文件改善應(yīng)用性能

文章出處:【微信公眾號:谷歌開發(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

    文章

    3917

    瀏覽量

    127061
  • 工作原理
    +關(guān)注

    關(guān)注

    4

    文章

    274

    瀏覽量

    37632

原文標(biāo)題:通過基準(zhǔn)配置文件改善應(yīng)用性能

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

收藏 人收藏

    評論

    相關(guān)推薦

    springboot的項目如何既要用jar包啟動,同時還可以為不同的機房設(shè)置不同的配置文件

    作者:京東科技 李意文 1、首先先把配置文件從jar中抽離 示例代碼: ? org.apache.maven.plugins maven-jar-plugin 3.2.0
    的頭像 發(fā)表于 10-19 16:48 ?370次閱讀
    springboot的項目如何既要用jar包<b class='flag-5'>啟動</b>,同時還可以為不同的機房設(shè)置不同的<b class='flag-5'>配置文件</b>

    HID over GATT配置文件(HOGP)低功耗藍(lán)牙

    電子發(fā)燒友網(wǎng)站提供《HID over GATT配置文件(HOGP)低功耗藍(lán)牙.pdf》資料免費下載
    發(fā)表于 09-26 11:01 ?0次下載
    HID over GATT<b class='flag-5'>配置文件</b>(HOGP)低功耗藍(lán)牙

    影響晶振啟動時間的因素

    晶振的啟動時間是指晶振通電到進(jìn)入穩(wěn)定振蕩狀態(tài)所需的時間。這個時間通常由晶振的內(nèi)部特性和外部電路決定。今天凱擎小妹帶大家具體了解一下影響啟動時間大小的因素吧!
    的頭像 發(fā)表于 09-06 11:10 ?308次閱讀

    鴻蒙開發(fā):【Stage模型應(yīng)用配置文件

    應(yīng)用配置文件中包含應(yīng)用配置信息、應(yīng)用組件信息、權(quán)限信息、開發(fā)者自定義信息等,這些信息在編譯構(gòu)建、分發(fā)和運行解決分別提供給編譯工具、應(yīng)用市場和操作系統(tǒng)使用。
    的頭像 發(fā)表于 06-15 09:15 ?1512次閱讀
    鴻蒙開發(fā):【Stage模型應(yīng)用<b class='flag-5'>配置文件</b>】

    在i.MXRT1xxx系列上用NAND型啟動設(shè)備時可用兩級設(shè)計縮短啟動時間

    去年痞子衡寫過一篇騷操作文章 《借助i.MXRT10xx系列INIT_VTOR功能可以縮短程序熱重啟時間》,這對于 NAND 型啟動設(shè)備上程序熱重啟時間
    的頭像 發(fā)表于 05-01 09:19 ?678次閱讀
    在i.MXRT1xxx系列上用NAND型<b class='flag-5'>啟動</b>設(shè)備時可用兩級設(shè)計<b class='flag-5'>縮短</b><b class='flag-5'>啟動時間</b>

    開關(guān)電源啟動性能檢測之啟動時間測試方法

    開關(guān)電源啟動時間測試是指打開電源后,測試電源輸出電壓開始變化到恢復(fù)穩(wěn)定的這段時間。啟動時間測試用來評估開關(guān)電源的啟動性能。在一些需要快速響應(yīng)的設(shè)備中,如果電源
    的頭像 發(fā)表于 01-22 16:25 ?1265次閱讀

    labview的opc生成配置文件

    的數(shù)據(jù)交互和通信。在 LabVIEW 中生成 OPC 配置文件有助于實現(xiàn)與其他設(shè)備的數(shù)據(jù)傳輸和共享,本文詳細(xì)介紹如何生成 OPC 配置文件。 首先,在 LabVIEW 中生成 OPC 配置文
    的頭像 發(fā)表于 12-26 17:57 ?1643次閱讀

    oracle配置文件類型關(guān)聯(lián)

    Oracle是一種業(yè)界領(lǐng)先的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它在大型企業(yè)中被廣泛使用。Oracle的配置文件對于數(shù)據(jù)庫的穩(wěn)定運行和性能優(yōu)化至關(guān)重要。在這篇文章中,我們詳細(xì)討論Oracle的一些重要配置文件
    的頭像 發(fā)表于 12-06 10:17 ?451次閱讀

    oracle配置文件tnsnames怎么配置

    Oracle配置文件tnsnames.ora是一個文本文件,用于定義數(shù)據(jù)庫連接的別名和連接信息。通過配置文件,可以在應(yīng)用程序中使用別名來連接數(shù)據(jù)庫,而不必直接給出數(shù)據(jù)庫的具體連接信息
    的頭像 發(fā)表于 12-06 10:15 ?7490次閱讀

    php的配置文件是什么

    ,配置文件的名稱默認(rèn)為php.ini。該文件通常位于PHP安裝目錄下的conf文件夾中。當(dāng)PHP解釋器啟動時,會自動加載php.ini文件,
    的頭像 發(fā)表于 12-04 15:55 ?1449次閱讀

    zookeeper的核心配置文件是什么

    Zookeeper是一個常用的分布式協(xié)調(diào)服務(wù),它被廣泛應(yīng)用于大型分布式系統(tǒng)中。Zookeeper的核心配置文件是zoo.cfg,它包含了Zookeeper服務(wù)器的各種配置參數(shù),可以通過修改這些參數(shù)
    的頭像 發(fā)表于 12-04 10:33 ?714次閱讀

    springboot的核心配置文件有哪些

    的工作量。 Spring Boot的核心配置文件主要有以下幾個: application.properties:Spring Boot應(yīng)用程序的主要配置文件。它使用Java的鍵值對格式來定義各種配置屬性
    的頭像 發(fā)表于 12-03 15:30 ?1122次閱讀

    springboot的全局配置文件有幾種

    、服務(wù)器端口等等。本文詳細(xì)介紹Spring Boot的全局配置文件,包括其類型、常見的配置項以及使用方法。 第一部分:Spring Boot全局配置文件的類型 Spring Boot
    的頭像 發(fā)表于 12-03 15:28 ?1490次閱讀

    linux修改網(wǎng)卡ip配置文件

    、子網(wǎng)掩碼、網(wǎng)關(guān)等參數(shù)。本文詳細(xì)介紹如何修改Linux的網(wǎng)卡ip配置文件。 首先,在Linux中,網(wǎng)絡(luò)接口的配置文件一般位于/etc/sysconfig/network-scripts/目錄下,
    的頭像 發(fā)表于 11-17 10:51 ?2108次閱讀

    電機啟動時間一般是多久?怎么縮短啟動時間呢?

    電機啟動時間一般是多久?我這個電機是132KW的,還有就是怎么縮短啟動時間,1S內(nèi)能啟動嗎?請高手解答 說了那么多,我還是沒明白啟動時間是多
    發(fā)表于 11-16 08:19