Start-up-Profile erstellen

Start-up-Profile sind eine Teilmenge der Baseline-Profile. Start-up-Profile werden von das Build-System, um die darin enthaltenen Klassen und Methoden weiter zu optimieren, das Layout des Codes in den DEX-Dateien deines APK verbessern. Mit Start-up-Profilen dass der Start Ihrer App bis zu 15% schneller ist als mit Baseline-Profilen allein.

<ph type="x-smartling-placeholder">
</ph>
Abbildung 1. Verbesserung der Codelokalität durch DEX-Layout Optimierung.

Voraussetzungen

Wir empfehlen, Start-up-Profile mit den folgenden Tools zu verwenden:

  • Jetpack Macro Benchmark 1.2.0 oder höher
  • Android-Gradle-Plug-in 8.2 oder höher
  • Android Studio Iguana oder höher

Darüber hinaus sind die folgenden Einstellungen in Ihrer App erforderlich:

  • R8 muss aktiviert sein. Legen Sie für Ihren Release-Build Folgendes fest: isMinifyEnabled = true
  • DEX-Layoutoptimierungen aktiviert. Im baselineProfile {}-Block des Build-Datei des App-Moduls auf dexLayoutOptimization = true festgelegt.

Start-up-Profil erstellen

Android Studio erstellt neben einem Baseline-Profil ein Start-up-Profil, wenn Sie die Standardvorlage „Baseline Profile Generator“ verwenden.

Die allgemeinen Schritte zum Erstellen und Generieren eines Start-up-Profils sind dieselben wie bei um ein Baseline-Profil zu erstellen.

Die Standardmethode zum Erstellen eines Start-up-Profils ist die Verwendung des Baseline-Profils Vorlage für Generatormodul in Android Studio. Dazu gehören Start-ups Interaktionen, die ein einfaches Start-up-Profil bilden. So erweitern Sie dieses Start-up-Profil mit mehr kritischen User Journeys (Critical User Journeys, CUJs) haben, fügen Sie Ihre App-Start-CUJs zu einem rule hinzu mit includeInStartupProfile auf true gesetzt. Bei einfachen Apps kann der Start Die MainActivity der App kann ausreichen. Bei komplexeren Anwendungen Ihrer App die häufigsten Einstiegspunkte hinzufügen, z. B. das Starten der App von zum Startbildschirm oder zu einem Deeplink.

Das folgende Code-Snippet zeigt einen Generator für Basisprofile (standardmäßig die BaselineProfileGenerator.kt-Datei), bei denen die App unter anderem aus dem und in einen Deeplink starten. Der Deeplink führt direkt zum aus dem Nachrichtenfeed der App, nicht aus dem Startbildschirm der App.

@RunWith(AndroidJUnit4::class)
@LargeTest
class BaselineProfileGenerator {

    @get:Rule
    val rule = BaselineProfileRule()

    @Test
    fun generate() {
        rule.collect(
            packageName = "com.example.app",
            includeInStartupProfile = true
        ) {
            // Launch directly into the NEWS_FEED.
            startActivityAndWait(Intent().apply {
                setPackage(packageName)
                setAction("com.example.app.NEWS_FEED")
            })
        }
    }
}

Führen Sie die Konfiguration Generate Baseline Profile for app (Baseline-Profil für Anwendung generieren) aus und suchen Sie nach der Regeln für Start-up-Profil unter src/<variant>/generated/baselineProfiles/startup-prof.txt

Optimierung von Start-up-Profilen bestätigen

Um die Optimierung des DEX-Layouts zu bestätigen, verwende Android Studio, um das APK zu öffnen und die Klassen in den DEX-Dateien überprüfen. Die primäre classes.dex darf nicht vollständig ausgefüllt sind. Wenn Ihre App nur aus einer einzigen DEX-Datei besteht, können Sie Gibt an, ob die Anwendung nach der Aktivierung des Startprofils zwei DEX-Dateien enthält.

Android Studio warnt Sie, wenn die Startklassen nicht in eine einzelne DEX-Datei passen. Um Diagnoseinformationen zu erhalten, die die Anzahl der Nicht-Startmethoden in die Startklassen, achten Sie darauf, dass der R8-Compiler mindestens auf die Version 8.3.36-dev durch folgende Änderungen an der Datei settings.gradle beim wenden Sie das Start-up-Profil an:

Kotlin

pluginManagement {
    buildscript {
        repositories {
            mavenCentral()
            maven {
                url = uri("https://storage.googleapis.com/r8-releases/raw")
            }
        }
        dependencies {
            classpath("com.android.tools:r8:8.3.6-dev")
        }
    }
}

Cool

pluginManagement {
    buildscript {
        repositories {
            mavenCentral()
            maven {
                url uri('https://storage.googleapis.com/r8-releases/raw')
            }
        }
        dependencies {
            classpath 'com.android.tools:r8:8.3.6-dev"
        }
    }
}

Füge danach --info hinzu assembleRelease im folgenden Befehl, wenn Sie Builds mit Gradle erstellen.

./gradlew assembleRelease --info

Die Diagnose wird dann an das Terminal ausgegeben.

Wenn Ihre App oder Bibliotheken auf nicht mehr unterstützte APIs verweisen, werden die gebündelten Kompatibilitätsimplementierungen dieser Klassen immer in der letzten DEX-Datei. Diese endgültige DEX-Datei ist nicht Teil des DEX-Layouts Optimierungen vor.