Configura la generazione del profilo di riferimento

Il plug-in Gradle di Baseline Profile semplifica la generazione e la gestione Profili di riferimento. Ti aiuta esegui le seguenti attività:

Questa pagina spiega come utilizzare il plug-in Gradle del profilo di base per personalizzare la generazione dei profili di riferimento.

Requisiti dei plug-in

Utilizzare un dispositivo gestito Gradle per generare profili di riferimento

Per utilizzare un dispositivo gestito da Gradle (GMD) per: genera il tuo profilo di riferimento, aggiungine uno nella configurazione build.gradle.kts del modulo producer profilo, probabilmente il modulo di test :baselineprofile, come come mostrato nell'esempio seguente:

Kotlin

android {
   testOptions.managedDevices.devices {
       create<com.android.build.api.dsl.ManagedVirtualDevice>("pixel6Api31") {
           device = "Pixel 6"
           apiLevel = 31
           systemImageSource = "aosp"
       }
   }
}

Alla moda

android {
   testOptions.managedDevices.devices {
       pixel6Api31(ManagedVirtualDevice) {
           device 'Pixel 6'
           apiLevel = 31
           systemImageSource 'aosp'
       }
   }
}

Utilizzare GMD per generare profili di riferimento aggiungendolo al profilo di base La configurazione del plug-in Gradle è la seguente:

Kotlin

baselineProfile {
    managedDevices += "pixel6Api31"
}

Alla moda

baselineProfile {
    managedDevices = ['pixel6Api31']
}

Quando utilizzi un GMD per generare profili di riferimento, imposta useConnectedDevices su false:

Kotlin

baselineProfile {
    ...
    useConnectedDevices = false
}

Alla moda

baselineProfile {
    ...
    useConnectedDevices false
}

Genera profili di riferimento per varianti diverse

Puoi generare profili di riferimento per variante, per versione o come singolo file da utilizzare per tutte le varianti. Controlla questo comportamento tramite l'impostazione di unione, ad esempio come mostrato nell'esempio che segue.

Kotlin

baselineProfile {
    mergeIntoMain = true
}

Alla moda

baselineProfile {
    mergeIntoMain true
}

Per unire i profili generati per tutte le varianti in un unico profilo, imposta Da mergeIntoMain a true. Non è possibile generare una base di riferimento per variante Profili quando questa impostazione è true, quindi è presente una singola attività Gradle chiamata generateBaselineProfile. L'output del profilo viene eseguito in src/main/generated/baselineProfiles.

Per disattivare l'unione e avere un profilo per variante, imposta mergeIntoMain su false. In questo caso, esistono più attività Gradle specifiche delle varianti. Per ad esempio, quando sono disponibili due versioni, senza costi e a pagamento, e una tipo di build della release, le attività sono le seguenti:

* `generateFreeReleaseBaselineProfile`
* `generatePaidReleaseBaselineProfile`
* `generateReleaseBaselineProfile`

Per specificare il comportamento di unione per variante, utilizza il seguente codice:

Kotlin

baselineProfile {
    variants {
        freeRelease {
            mergeIntoMain = true
        }
    }
}

Alla moda

baselineProfile {
    variants {
        freeRelease {
            mergeIntoMain true
        }
    }
}

Nell'esempio precedente, le varianti in cui il flag è impostato su true sono tutte sono stati uniti in src/main/generated/baselineProfiles, mentre i profili per le varianti in cui il flag è impostato su false rimangono nella cartella src/<variant>/generated/baselineProfiles.

Per impostazione predefinita, il criterio mergeIntoMain è impostato su true per le raccolte e su false per le app.

Genera automaticamente profili di riferimento durante l'assemblaggio di una nuova release

Puoi configurare i profili di riferimento in modo che generino automaticamente con ogni release anziché utilizzare manualmente l'attività generateBaselineProfile. Con la generazione automatica, nella build della release è incluso il profilo più aggiornato.

Per abilitare la generazione automatica per le build della release, usa la automaticGenerationDuringBuild flag:

Kotlin

baselineProfile {
    automaticGenerationDuringBuild = true
}

Alla moda

baselineProfile {
    automaticGenerationDuringBuild true
}

L'impostazione del flag automaticGenerationDuringBuild su true attiva la generazione di un nuovo profilo di riferimento per ogni gruppo di release. Ciò significa che eseguendo un'attività di assemblaggio della release, ad esempio ./gradlew:app:assembleRelease attiva anche :app:generateReleaseBaselineProfile, avvia il profilo di riferimento di strumentazione e crea la build del profilo di riferimento su cui vengono eseguite. Sebbene la generazione automatica aiuti gli utenti a ottenere i migliori vantaggi in termini di prestazioni, aumenta anche i tempi di compilazione grazie alla doppia build e alla strumentazione test.

Puoi anche specificare questo comportamento per variante, come illustrato di seguito esempio:

Kotlin

baselineProfile {
    variants {
        freeRelease {
            automaticGenerationDuringBuild = true
        }
    }
}

Alla moda

baselineProfile {
    variants {
        freeRelease {
            automaticGenerationDuringBuild true
        }
    }
}

Nell'esempio precedente, l'attività generateFreeReleaseBaselineProfile viene eseguita all'avvio di assembleFreeRelease. Questo aiuta quando l'utente vuole avere, ad ad esempio una build release per la distribuzione che genera sempre il profilo. durante la creazione e una build releaseWithoutProfile per i test interni.

Archivia i profili di riferimento in sorgenti

Puoi archiviare i profili di riferimento nella directory di origine tramite saveInSrc Segnala:

  • true: il profilo di riferimento è memorizzato in src/<variant>/generated/baselineProfiles. Questo ti permette di eseguire il commit generato con le tue origini.
  • false: il profilo di base viene archiviato nei file intermedi nella build . In questo modo, quando esegui il commit del codice, non salvi la versione generato automaticamente.

Kotlin

baselineProfile {
    saveInSrc = true
}

Alla moda

baselineProfile {
    saveInSrc true
}

Puoi anche specificare questo comportamento per variante:

Kotlin

baselineProfile {
    variants {
        freeRelease {
            saveInSrc = true
        }
    }
}

Alla moda

baselineProfile {
    variants {
        freeRelease {
            saveInSrc true
        }
    }
}

Filtra regole del profilo

Il plug-in Gradle del profilo di base consente di filtrare le regole del profilo di base generati. Ciò è particolarmente utile per le librerie, se vuoi escludere regole del profilo per classi e metodi che fanno parte di altre dipendenze del un'app di esempio o la raccolta stessa. I filtri possono includere ed escludere pacchetti e classi. Se specifichi solo le esclusioni, viene applicato solo il valore corrispondente alla base di riferimento Le regole del profilo sono escluse e tutto il resto è incluso.

Le specifiche dei filtri possono essere:

  • Il nome del pacchetto termina con doppi caratteri jolly per corrispondere al pacchetto specificato e per tutti i sottopacchetti. Ad esempio, com.example.** corrisponde a com.example.method e com.example.method.bar.
  • Nome del pacchetto che termina con un carattere jolly per corrispondere solo al pacchetto specificato. Per Ad esempio, com.example.* corrisponde a com.example.method ma non corrisponde com.example.method.bar.
  • Nomi di classi che corrispondono a una classe specifica, ad esempio com.example.MyClass.

I seguenti esempi mostrano come includere ed escludere pacchetti specifici:

Kotlin

baselineProfile {
    filter {
        include("com.somelibrary.widget.grid.**")
        exclude("com.somelibrary.widget.grid.debug.**")
        include("com.somelibrary.widget.list.**")
        exclude("com.somelibrary.widget.list.debug.**")
        include("com.somelibrary.widget.text.**")
        exclude("com.somelibrary.widget.text.debug.**")
    }
}

Alla moda

baselineProfile {
    filter {
        include 'com.somelibrary.widget.grid.**'
        exclude 'com.somelibrary.widget.grid.debug.**'
        include 'com.somelibrary.widget.list.**'
        exclude 'com.somelibrary.widget.list.debug.**'
        include 'com.somelibrary.widget.text.**'
        exclude 'com.somelibrary.widget.text.debug.**'
    }
}

Personalizza le regole del filtro per varianti diverse come segue:

Kotlin

// Non-specific filters applied to all the variants.
baselineProfile {
    filter { include("com.myapp.**") }
}

// Flavor-specific filters.
baselineProfile {
    variants {
        free {
            filter {
                include("com.myapp.free.**")
            }
        }
        paid {
            filter {
                include("com.myapp.paid.**")
            }
        }
    }
}

// Build-type-specific filters.
baselineProfile {
    variants {
        release {
            filter {
                include("com.myapp.**")
            }
        }
    }
}

// Variant-specific filters.
baselineProfile {
    variants {
        freeRelease {
            filter {
                include("com.myapp.**")
            }
        }
    }
}

Alla moda

// Non-specific filters applied to all the variants.
baselineProfile {
    filter { include 'com.myapp.**' }
}

// Flavor-specific filters.
baselineProfile {
    variants {
        free {
            filter {
                include 'com.myapp.free.**'
            }
        }
        paid {
            filter {
                include 'com.myapp.paid.**'
            }
        }
    }
}

// Build-type specific filters.
baselineProfile {
    variants {
        release {
            filter {
                include 'com.myapp.**'
            }
        }
    }
}

// Variant-specific filters.
baselineProfile {
    variants {
        freeRelease {
            filter {
                include 'com.myapp.**'
            }
        }
    }
}

Puoi anche filtrare le regole utilizzando l'argomento filterPredicate in BaselineProfileRule.collect(), ma ti consigliamo di utilizzare l'API Gradle plug-in per filtrare perché consente di filtrare più facilmente i sottopacchetti e posto in un unico posto per configurare l'intero modulo.

Personalizzare i tipi di build Benchmark e Profilo di riferimento

Il plug-in Gradle del profilo di base crea tipi di build aggiuntivi da generare i profili ed eseguire benchmark. Questi tipi di build sono preceduti dal prefisso benchmark e nonMinified. Ad esempio, per il tipo di build release, la classe crea i tipi di build benchmarkRelease e nonMinifiedRelease. Questi tipi di build vengono configurati automaticamente per il caso d'uso specifico non richiedono solitamente alcuna personalizzazione. Ma ci sono alcuni casi in cui potrebbe comunque essere utile applicare alcune opzioni personalizzate, ad esempio per applicare configurazione di firma diversa.

Puoi personalizzare i tipi di build generati automaticamente utilizzando un sottoinsieme di le proprietà del tipo di build; le proprietà non utilizzabili vengono sostituite. L'esempio seguente mostra come personalizzare i tipi di build aggiuntivi e quali proprietà vengono sostituite:

Kotlin

android {
    buildTypes {
        release {
            ...
        }
        benchmarkRelease {
            // Customize properties for the `benchmarkRelease` build type here.
            // For example, you can change the signing config (by default
            // it's the same as for the `release` build type).
            signingConfig = signingConfigs.getByName("benchmarkRelease")
        }
        nonMinifiedRelease {
            // Customize properties for the `nonMinifiedRelease` build type here.
            signingConfig = signingConfigs.getByName("nonMinifiedRelease")

            // From Baseline Profile Gradle plugin 1.2.4 and higher, you can't
            // customize the following properties, which are always overridden to
            // avoid breaking Baseline Profile generation:
            //
            // isJniDebuggable = false
            // isDebuggable = false
            // isMinifyEnabled = false
            // isShrinkResources = false
            // isProfileable = true
            // enableAndroidTestCoverage = false
            // enableUnitTestCoverage = false
        }
    }
}

Alla moda

android {
    buildTypes {
        release {
            ...
        }
        benchmarkRelease {
            // Customize properties for the `benchmarkRelease` build type here.
            // For example, you can change the signing config (by default it's the
            // same as for the `release` build type.)
            signingConfig = signingConfigs.benchmarkRelease
        }
        nonMinifiedRelease {
            // Customize properties for the `nonMinifiedRelease` build type here.
            signingConfig = signingConfigs.nonMinifiedRelease

            // From Baseline Profile Gradle plugin 1.2.4 and higher, you can't use
            // the following properties, which are always overridden to avoid breaking
            // Baseline Profile generation:
            //
            // isJniDebuggable = false
            // isDebuggable = false
            // isMinifyEnabled = false
            // isShrinkResources = false
            // isProfileable = true
            // enableAndroidTestCoverage = false
            // enableUnitTestCoverage = false       
        }
    }
}

Note aggiuntive

Quando crei profili di riferimento, tieni presente quanto segue:

  • I profili di riferimento compilati devono avere dimensioni inferiori a 1,5 MB. Non al formato di testo nei file di origine, che in genere sono molto prima della compilazione. Verifica la dimensione della base di riferimento binaria Profilo individuandolo nell'artefatto di output in assets/dexopt/baseline.prof per l'APK o BUNDLE-METADATA/com.android.tools.build.profiles/baseline.prof per AAB.

  • Regole generiche che compilano un numero eccessivo di applicazioni possono rallentare l'avvio grazie all'aumento dell'accesso al disco. Se stai iniziando con Baseline Profili, non preoccuparti. Tuttavia, a seconda dell'app e del dimensione e numero di percorsi, l'aggiunta di molti percorsi può un rendimento non ottimale. Testa le prestazioni della tua app provando diverse profili e verificare che il rendimento non regredisce dopo il aggiunte.

Codelab

Approfondisci il tema del macrobenchmarking per misurare il rendimento.
Genera un profilo di riferimento personalizzato per un'app per Android e verificane l'efficacia.