Eseguire il benchmark della tua app

Il benchmarking è un modo per esaminare e monitorare le prestazioni della tua app. Puoi eseguire regolarmente benchmark per analizzare ed eseguire il debug dei problemi di prestazioni e contribuire a garantire di non introdurre regressioni nelle modifiche recenti.

Android offre due librerie e approcci di benchmarking per analizzare e testare diversi tipi di situazioni nella tua app: Macrobenchmark e Microbenchmark.

Macrobenchmark

La libreria Macrobenchmark misura le interazioni più grandi degli utenti finali, come l'avvio, l'interazione con la UI e le animazioni. La libreria fornisce il controllo diretto sull'ambiente di rendimento che stai testando. Ti consente di controllare la compilazione e di avviare e interrompere l'app per misurare direttamente l'avvio o lo scorrimento effettivo dell'app.

La libreria Macrobenchmark inserisce eventi e monitora i risultati esternamente da un'app di test creata con i tuoi test. Pertanto, quando scrivi i benchmark, non chiami direttamente il codice dell'app, ma navighi all'interno dell'app come utente.

Microbenchmark

La libreria Microbenchmark ti consente di eseguire il benchmark del codice dell'app direttamente in un ciclo. È progettato per misurare il lavoro della CPU che valuta le prestazioni nel migliore dei casi, ad esempio l'accesso JIT (Just in Time) e al disco memorizzato nella cache, che potresti vedere con un ciclo interno o una funzione specifica. ​​La libreria può misurare solo il codice che puoi chiamare direttamente in isolamento.

Se la tua app deve elaborare una struttura di dati complessa o ha un algoritmo specifico che richiede molti calcoli e viene chiamato più volte durante l'esecuzione dell'app, questi potrebbero essere buoni casi per il benchmarking. Puoi anche misurare parti della tua UI. Ad esempio, puoi misurare il costo del binding dell'elemento RecyclerView, il tempo necessario per gonfiare un layout o quanto è impegnativo il passaggio di layout e misurazione della classe View dal punto di vista delle prestazioni.

Tuttavia, non puoi misurare il contributo dei casi di benchmark all'esperienza utente complessiva. In alcuni scenari, il benchmarking non indica se stai migliorando un collo di bottiglia come il jank o il tempo di avvio dell'app. Per questo motivo, è fondamentale identificare prima questi colli di bottiglia con Android Profiler. Dopo aver trovato il codice che vuoi esaminare e ottimizzare, il ciclo di benchmark può essere eseguito ripetutamente in modo rapido e semplice per creare risultati meno rumorosi, il che ti consente di concentrarti su un'area di miglioramento.

La libreria Microbenchmark segnala solo informazioni sulla tua app, non sul sistema nel suo complesso. Pertanto, è ideale per analizzare le prestazioni di situazioni specifiche dell'app, non quelle che potrebbero essere correlate a problemi generali del sistema.

Confronto della raccolta di benchmark

Macrobenchmark Microbenchmark
Versione API 23 e versioni successive 14 e versioni successive
Funzione Misura i punti di ingresso o le interazioni di alto livello, come l'avvio di un'attività o lo scorrimento di un elenco. Misura le singole funzioni.
Ambito Test out-of-process dell'app completa. Test in corso del lavoro della CPU.
Velocità Velocità di iterazione media. Può superare un minuto. Velocità di iterazione rapida. Spesso meno di 10 secondi.
Monitoraggio I risultati includono tracce di profilazione. Campionamento e tracciamento facoltativi dei metodi.