Para oferecer a melhor experiência do usuário, otimize seu app para que ele seja o menor e mais rápido possível. Nosso otimizador de apps, chamado R8, simplifica o app removendo códigos e recursos não utilizados, reescrevendo o código para otimizar a performance de execução e muito mais. Para os usuários, isso significa:
- Tempo de inicialização mais rápido
- Uso da memória reduzido
- Renderização e performance de execução aprimoradas
- Menos ANRs
Visão geral da otimização do R8
O R8 usa um processo de várias fases para otimizar o tamanho e a velocidade do app. As principais operações incluem o seguinte:
Redução de código (também conhecida como tree shaking): o R8 identifica e remove códigos inacessíveis do aplicativo e das dependências da biblioteca. Ao analisar os pontos de entrada do app (como
ActivitiesouServicesdefinidos no manifesto), o R8 cria um gráfico de código referenciado e remove tudo o que não for referenciado.Otimizações lógicas: o R8 reescreve o código para melhorar a eficiência da execução e reduzir a sobrecarga. As principais técnicas incluem:
Inlining de método: o R8 substitui um local de chamada de método pelo corpo real do método chamado. Isso elimina a sobrecarga de uma chamada de função e permite que o R8 realize outras otimizações.
Mesclagem de classes: o R8 combina conjuntos de classes e interfaces em uma única classe. Isso reduz o número de classes no app, diminuindo a pressão da memória e melhorando a velocidade de inicialização.
Ofuscação (também conhecida como minificação): para reduzir o tamanho do arquivo DEX , o R8 encurta os nomes de classes, campos e métodos (por exemplo,
com.example.MyActivitypode se tornara.b.a).
Desde a versão 8.12.0 do Plug-in do Android para Gradle (AGP), o R8 também otimiza os recursos como parte das fases de otimização. Para mais informações, consulte Redução de recursos otimizada.
Ativar a otimização
Para ativar a otimização do app, defina isMinifyEnabled = true (para otimização de código)
e isShrinkResources = true (para otimização de recursos) no script de build do app no build de lançamento
build's, conforme mostrado no código a seguir. Recomendamos que você sempre ative as duas configurações. Também recomendamos ativar a otimização do app apenas na versão final do app que você testa antes da publicação, geralmente o build de lançamento, porque as otimizações aumentam o tempo de build do projeto e podem dificultar a depuração devido à forma como o código é modificado.
Kotlin
android { buildTypes { release { // Enables code-related app optimization. isMinifyEnabled = true // Enables resource shrinking. isShrinkResources = true proguardFiles( // Default file with automatically generated optimization rules. getDefaultProguardFile("proguard-android-optimize.txt"), ... ) ... } } ... }
Groovy
android { buildTypes { release { // Enables code-related app optimization. minifyEnabled = true // Enables resource shrinking. shrinkResources = true // Default file with automatically generated optimization rules. proguardFiles getDefaultProguardFile('proguard-android-optimize.txt') ... } } }
Otimizar a redução de recursos para apps ainda menores
A versão 8.12.0 do Plug-in do Android para Gradle (AGP) apresenta a redução de recursos otimizada, que visa integrar a otimização de recursos e códigos para criar apps ainda menores e mais rápidos.
Antes da redução de recursos otimizada, a Android Asset Packaging Tool (AAPT2) gerava regras de manutenção que tratavam a redução de recursos separadamente do código, muitas vezes retendo códigos ou recursos inacessíveis que se referiam uns aos outros.
Com a redução de recursos otimizada, os recursos são considerados como parte do código do programa, formando o gráfico de referência. Quando uma coleção de códigos ou recursos não é referenciada, ela não é protegida por uma regra de manutenção e pode ser removida.
Ativar a redução de recursos otimizada
Para ativar o novo pipeline de redução de recursos otimizado para uma versão do AGP anterior à 9.0.0, adicione o seguinte ao arquivo gradle.properties do projeto:
android.r8.optimizedResourceShrinking=true
Se você estiver usando o AGP 9.0.0 ou uma versão mais recente, não será necessário definir android.r8.optimizedResourceShrinking=true. A redução de recursos otimizada é aplicada automaticamente quando isShrinkResources = true está ativada na configuração de build.
Verificar e configurar as configurações de otimização do R8
android.enableR8.fullMode=false # Remove this line from your codebase.
A ativação da otimização do app dificulta a compreensão dos stack traces, especialmente se o R8 renomear nomes de classes ou métodos. Para receber stack traces que correspondam corretamente ao código-fonte, consulte Recuperar o stack trace original.
Se o R8 estiver ativado, também será necessário criar perfis de inicialização para uma performance de inicialização ainda melhor.
Se você ativar a otimização do app e ela causar erros, confira algumas estratégias para corrigi-los:
- Adicione regras de manutenção para manter alguns códigos intactos.
- Adote otimizações de forma incremental.
- Atualize o código para usar bibliotecas mais adequadas para otimização.
Se você quiser otimizar a velocidade do build, consulte Configurar como o R8 é executado para informações sobre como configurar o R8 com base no seu ambiente.
Mudanças no comportamento da versão do AGP e do R8
A tabela a seguir descreve os principais recursos introduzidos em várias versões do Plug-in do Android para Gradle (AGP) e do compilador R8.
| Versão do AGP | Recursos introduzidos |
|---|---|
| 9.1 |
Classes reempacotadas por padrão:o R8 reempacota classes (movendo-as para o pacote sem nome, no nível superior) para compactar ainda mais o DEX, eliminando a necessidade de especificar a opção -repackageclasses. Para informações sobre como isso funciona e como desativar, consulte Opções globais.
|
| 9.0 |
Redução de recursos otimizada: ativada por padrão (controlada usando android.r8.optimizedResourceShrinking). A redução de recursos otimizada ajuda a integrar a redução de recursos ao pipeline de otimização de código, resultando em apps menores e mais rápidos. Ao otimizar as referências de código e recursos simultaneamente, ela identifica e remove recursos referenciados exclusivamente de códigos não utilizados. Essa é uma melhoria significativa em relação aos processos de otimização separados anteriores.Isso é especialmente útil para apps que compartilham recursos e códigos substanciais em diferentes verticais de fator de forma, com melhorias medidas de mais de 50% no tamanho do app. A redução de tamanho resultante leva a downloads menores, instalações mais rápidas e uma melhor experiência do usuário com inicialização mais rápida, renderização aprimorada e menos ANRs. Filtragem de regras de biblioteca:o suporte para opções globais (por exemplo, -dontobfuscate) em regras de consumidor de biblioteca foi removido, e os apps vão filtrá-las. Para mais informações, consulte Adicionar opções globais.Verificações nulas do Kotlin:otimizadas por padrão (controladas usando -processkotlinnullchecks). Essa versão também introduziu melhorias significativas na velocidade do build. Para mais informações, consulte Opções globais para otimização adicional.Otimizar pacotes específicos:é possível usar packageScope para otimizar pacotes específicos. Isso está em suporte experimental. Para mais informações, consulte Otimizar pacotes especificados com packageScope.Otimizado por padrão:o suporte para getDefaultProguardFile("proguard-android.txt") foi removido porque inclui -dontoptimize, que precisa ser evitado. Em vez disso, use "proguard-android-optimize.txt". Se você precisar desativar globalmente a otimização no app, adicione a flag manualmente a um arquivo ProGuard.
|
| 8.12 |
Redução de recursos:suporte inicial adicionado (desativado por padrão. Ative usando isShrinkResources). A redução de recursos funciona em conjunto com o R8 para identificar e remover recursos não utilizados de maneira eficaz.Retraçamento do Logcat: suporte para retraçamento automático na janela do Logcat do Android Studio. |
| 8.6 |
Retraçamento aprimorado:inclui o retraçamento de nome de arquivo e número de linha por padrão para todos os níveis de minSdk (anteriormente exigia minSdk 26 ou mais na versão 8.2).A atualização do R8 ajuda a garantir que os stack traces de builds ofuscados sejam facilmente e claramente legíveis. Essa versão melhora a forma como os números de linha e os arquivos de origem são mapeados, facilitando que ferramentas como o Logcat do Android Studio retraçam automaticamente falhas no código-fonte original. |
| 8.0 |
Modo completo por padrão: o modo completo do R8 oferece uma otimização significativamente mais poderosa. Ele está ativado por padrão. É possível desativar usando android.enableR8.fullMode=false.
|
| 7.0 |
Modo completo disponível:introduzido como um recurso de ativação usando android.enableR8.fullMode=true. O modo completo aplica otimizações mais poderosas, fazendo suposições mais rigorosas sobre como o código usa reflexão e outros recursos dinâmicos. Embora reduza o tamanho do app e melhore a performance, ele pode exigir regras de manutenção adicionais para evitar que o código necessário seja removido.
|