Crea profili di avvio

I profili di avvio sono un sottoinsieme dei profili di base. I profili di avvio vengono utilizzati dal sistema di build per ottimizzare ulteriormente le classi e i metodi che contengono migliorando il layout del codice nei file DEX dell'APK. Con i profili di avvio, l'avvio dell'app è in genere più veloce del 15-30% rispetto ai soli profili di base.

Figura 1. Miglioramento della località del codice grazie all'ottimizzazione del layout DEX

Requisiti

Ti consigliamo di utilizzare i profili di avvio con i seguenti strumenti:

  • Jetpack Macrobenchmark 1.2.0 o versioni successive
  • Plug-in Android per Gradle 8.2 o versioni successive
  • Android Studio Iguana o versioni successive

Inoltre, devi avere le seguenti impostazioni nella tua app:

  • R8 abilitato. Per la build di release, imposta isMinifyEnabled = true.
  • Ottimizzazioni del layout DEX abilitate. Nel blocco baselineProfile {} del file di build del modulo dell'app, imposta dexLayoutOptimization = true.

Creare un profilo di avvio

Android Studio crea un profilo di avvio insieme a un profilo di base quando utilizzi il modello predefinito del generatore di profili di base.

I passaggi generali per creare e generare un profilo di avvio sono gli stessi di quelli per creare un profilo di base.

Il modo predefinito per creare un profilo di avvio è utilizzare il modello di modulo del generatore di profili di base in Android Studio. Sono incluse le interazioni di avvio che formano un profilo di avvio di base. Per aumentare questo profilo di avvio con altri percorsi utente critici (CUJ), aggiungi i CUJ di avvio dell'app a un blocco rule con includeInStartupProfile impostato su true. Per le app semplici, potrebbe essere sufficiente avviare l'app MainActivity. Per le app più complesse, valuta la possibilità di aggiungere i punti di accesso più comuni all'app, ad esempio l'avvio dell'app dalla schermata Home o l'avvio in un link diretto.

Il seguente snippet di codice mostra un generatore di profili di base (per impostazione predefinita il BaselineProfileGenerator.kt file) che include l'avvio in un link diretto. Il link diretto rimanda direttamente al feed di notizie dell'app, non alla schermata Home dell'app.

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

    @get:Rule
    val rule = BaselineProfileRule()

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

Esegui la configurazione Genera profilo di base per l'app e trova le regole del profilo di avvio in src/<variant>/generated/baselineProfiles/startup-prof.txt.

Considerazioni per la creazione di profili di avvio

Per decidere quali percorsi utente coprire durante la creazione di un profilo di avvio, considera da dove la maggior parte degli utenti avvia l'applicazione. Di solito è dal launcher e dopo aver eseguito l'accesso. Questo è anche il percorso del profilo di base più semplice.

Dopo aver trattato il primo caso d'uso, segui il funnel utente per l'avvio dell'app. In molti casi, i funnel di avvio dell'app seguono questo elenco:

  1. Attività del launcher principale
  2. Notifiche che attivano l'avvio dell'app
  3. Attività del launcher facoltative

Lavora su questo elenco dall'alto e fermati prima che classes.dex sia pieno. Per coprire più percorsi in un secondo momento, sposta il codice dal percorso di avvio e aggiungi altri percorsi. Per spostare il codice dal percorso di avvio, esamina le tracce di Perfetto durante l'avvio dell'app e cerca le operazioni a lunga esecuzione. Puoi anche utilizzare un macrobenchmark con la traccia dei metodi abilitata per una visualizzazione automatica e completa delle chiamate di metodi durante l'avvio dell'app.