Suporte a tamanhos de página de 16 KB

Requisito de compatibilidade de 16 KB do Google Play
A partir de 1º de novembro de 2025, todos os novos apps e atualizações de apps enviados ao Google Play e destinados a dispositivos Android 15 ou mais recentes precisarão oferecer suporte a tamanhos de página de 16 KB em dispositivos de 64 bits.

Historicamente, o Android só ofereceu suporte a tamanhos de página de memória de 4 KB, o que otimizou o desempenho da memória do sistema para a quantidade média de memória total que os dispositivos Android normalmente tinham. A partir do Android 15, o AOSP oferece suporte a dispositivos configurados para usar um tamanho de página de 16 KB (dispositivos de 16 KB). Se o app usar alguma biblioteca do NDK, seja direta ou indiretamente por um SDK, será necessário recriar o app para que ele funcione nesses dispositivos de 16 KB.

À medida que os fabricantes de dispositivos continuam criando dispositivos com quantidades maiores de memória física (RAM), muitos deles vão adotar tamanhos de página de 16 KB (e eventualmente maiores) para otimizar o desempenho do dispositivo. Ao adicionar suporte para dispositivos com tamanho de página de 16 KB, você permite que o app seja executado nesses dispositivos e aproveite as melhorias de desempenho associadas. Sem recompilação, os apps não vão funcionar em dispositivos de 16 KB em versões futuras do Android.

Para ajudar você a adicionar suporte ao app, fornecemos orientações sobre como verificar se o app foi afetado, como recompilar o app (se aplicável) e como testar o app em um ambiente de 16 KB usando emuladores (incluindo imagens do sistema Android 15 para o Android Emulator).

Benefícios e ganhos de performance

Os dispositivos configurados com tamanhos de página de 16 KB usam um pouco mais de memória em média, mas também têm várias melhorias de desempenho para o sistema e os apps:

  • Tempos de inicialização do app mais rápidos enquanto o sistema está sob pressão de memória: 3,16% mais baixos em média, com melhorias mais significativas (até 30%) em alguns apps testados.
  • Redução do consumo de energia durante o lançamento do app: redução média de 4,56%
  • Lançamento mais rápido da câmera: 4,48% mais rápido em média e 6,60% mais rápido em média
  • Tempo de inicialização do sistema melhorado: melhoria de 8% (aproximadamente 950 milissegundos) em média

Essas melhorias são baseadas nos testes iniciais, e os resultados em dispositivos reais provavelmente serão diferentes. Forneceremos análises adicionais de ganhos em potencial para apps à medida que continuarmos nossos testes.

Verificar se o app foi afetado

Se o app usar código nativo, recompile o app com suporte para dispositivos de 16 KB. Se você não tiver certeza se o app usa código nativo, use o APK Analyzer para identificar se há código nativo e verifique o alinhamento dos segmentos ELF de bibliotecas compartilhadas encontradas. O Android Studio também oferece recursos que ajudam a detectar automaticamente problemas de alinhamento.

Se o app usa apenas código escrito na linguagem de programação Java ou Kotlin, incluindo bibliotecas ou SDKs, ele já oferece suporte a dispositivos de 16 KB. No entanto, recomendamos que você teste o app em um ambiente de 16 KB para verificar se não há regressões inesperadas no comportamento do app.

O app usa código nativo?

Seu app usa código nativo se alguma das seguintes condições for verdadeira:

  • O app usa código C/C++ (nativo). Se o app usa o Android NDK, ele usa código nativo.
  • O app se vincula a bibliotecas ou dependências nativas de terceiros (como SDKs) que as usam.
  • O app é criado por um criador de apps de terceiros que usa bibliotecas nativas no dispositivo.

Identificar bibliotecas nativas usando o APK Analyzer

O APK Analyzer é uma ferramenta que permite avaliar vários aspectos de um APK. Para verificar se o app usa código nativo (independentemente de ser compatível com 16 KB):

  1. Abra o Android Studio, clique em File > Open e escolha qualquer projeto.
  2. Na barra de menus, clique em Build > Analyze APK…

    Opção do menu "Build" do Studio para iniciar o APK Analyzer
  3. Escolha o APK que você quer analisar.

  4. Confira se há algum arquivo de objeto compartilhado (.so) na pasta lib. Se houver arquivos de objeto compartilhado, o app usa código nativo. A coluna Alignment mostra mensagens de aviso para arquivos que têm problemas de alinhamento. Se não houver arquivos de objeto compartilhado ou se não houver uma pasta lib, o app não usa código nativo.

    Visualização do APK Analyzer mostrando que os arquivos de objeto compartilhado estão presentes

Detectar problemas de alinhamento com verificações automatizadas

O Android Studio avisa proativamente se as bibliotecas ou APKs pré-criados não forem compatíveis com 16 KB. Use a ferramenta APK Analyzer para revisar quais bibliotecas precisam ser atualizadas ou se alguma mudança de código é necessária.

Notificações de aviso do Studio sobre problemas de alinhamento em um projeto

O Lint no Android Studio também destaca bibliotecas nativas que não estão alinhadas com 16 KB.

Aviso do linter do Studio sobre uma biblioteca nativa não alinhada

Verificar o alinhamento de segmentos ELF para bibliotecas compartilhadas

Para qualquer biblioteca compartilhada, verifique se os segmentos ELF estão alinhados corretamente usando o alinhamento ELF de 16 KB. Se você estiver desenvolvendo no Linux ou no macOS, poderá usar o script check_elf_alignment.sh, conforme descrito na seção a seguir. Também é possível usar as ferramentas de linha de comando diretamente.

Usar o script check_elf_alignment.sh (Linux ou macOS)

Siga estas etapas para verificar o alinhamento de segmentos ELF usando o script check_elf_alignment.sh:

  1. Salve o check_elf_alignment.sh script em um arquivo.

  2. Execute o script no arquivo APK do app:

    check_elf_alignment.sh APK_NAME.apk
    

    O script gera ALIGNED ou UNALIGNED para todas as arm64-v8a bibliotecas compartilhadas.

  3. Se alguma biblioteca compartilhada arm64-v8a ou x86_64 estiver UNALIGNED, será necessário atualizar o pacote dessas bibliotecas, recompilar o app e testar novamente seguindo as etapas desta seção.

Usar ferramentas de linha de comando diretamente

Siga estas etapas para verificar o alinhamento de segmentos ELF usando ferramentas de linha de comando diretamente:

  1. Verifique se o SDK do Android Build-Tools versão 35.0.0 ou mais recente e o Android NDK estão instalados usando o SDK Manager no Android Studio ou sdkmanager ferramenta de linha de comando.
  2. Extraia o arquivo APK do app:

    Linux ou macOS

    unzip APK_NAME.apk -d /tmp/my_apk_out
    

    Windows (PowerShell)

    Expand-Archive -Path .\APK_NAME.apk -DestinationPath ~\tmp\my_apk_out
    
  3. No diretório temporário em que você extraiu o arquivo APK, verifique o conteúdo do diretório lib para arquivos de objeto compartilhado (.so). Esses são os mesmos arquivos de objeto compartilhado que você teria visto ao identificar bibliotecas nativas usando o APK Analyzer. Execute o comando a seguir em cada arquivo de objeto compartilhado:

    Linux ou macOS

    SDK_ROOT_LOCATION/Android/sdk/ndk/NDK_VERSION/toolchains/llvm/prebuilt/darwin-x86_64/bin/llvm-objdump -p SHARED_OBJECT_FILE.so | grep LOAD
    

    Windows (PowerShell)

    SDK_ROOT_LOCATION\Android\sdk\ndk\NDK_VERSION\toolchains\llvm\prebuilt\windows-x86_64\bin\llvm-objdump.exe -p SHARED_OBJECT_FILE.so | Select-String -Pattern "LOAD"
    

    Em que SDK_ROOT_LOCATION é o caminho para o diretório em que você instalou o SDK do Android, SHARED_OBJECT_FILE é o nome do arquivo de objeto compartilhado que você está verificando e NDK_VERSION é a versão do Android NDK que você instalou (por exemplo, 28.0.12433566). A saída será semelhante à seguinte para cada arquivo verificado:

    LOAD off    0x0000000000000000 vaddr 0x0000000000000000 paddr 0x0000000000000000 align 2**14
    LOAD off    0x0000000000042a90 vaddr 0x0000000000043a90 paddr 0x0000000000043a90 align 2**14
    LOAD off    0x0000000000046230 vaddr 0x0000000000048230 paddr 0x0000000000048230 align 2**14
    
  4. Verifique as linhas de saída para garantir que os segmentos de carregamento não tenham valores menores que 2**14. Se algum segmento de carregamento for 2**13, 2**12, ou valores menores, será necessário atualizar o pacote dessas bibliotecas, então recompilar seu app e testar novamente seguindo as etapas desta seção.

  5. Em seguida, execute a ferramenta de linha de comando zipalign no arquivo APK do app:

    Linux ou macOS

    SDK_ROOT_LOCATION/Android/sdk/build-tools/35.0.0/zipalign -v -c -P 16 4 APK_NAME.apk
    

    Windows (PowerShell)

    SDK_ROOT_LOCATION\Android\sdk\build-tools\35.0.0\zipalign.exe -v -c -P 16 4 APK_NAME.apk
    

    Em que SDK_ROOT_LOCATION é o caminho para o diretório em que você instalou o SDK do Android e APK_NAME é o nome do arquivo APK do app. A última linha da saída vai dizer "Verification successful" se todas as bibliotecas compartilhadas estiverem alinhadas corretamente.

    Se a verificação falhar, algumas bibliotecas compartilhadas precisarão ser realinhadas. Portanto, será necessário atualizar o pacote dessas bibliotecas, então recompilar o app e testar novamente seguindo as etapas desta seção.

Criar um app com suporte a dispositivos de 16 KB

Se o app usa código nativo, conclua as etapas descritas nas seções a seguir para garantir que ele ofereça suporte a dispositivos de 16 KB:

  1. Atualizar o pacote das bibliotecas compartilhadas
  2. Compilar o app usando o alinhamento ELF de 16 KB
  3. Corrigir o código e resolver problemas de execução
  4. Verificar se os SDKs oferecem suporte a 16 KB

Atualizar o pacote das bibliotecas compartilhadas

Faça upgrade para a versão 8.5.1 ou mais recente do AGP e use bibliotecas compartilhadas não compactadas.

Usar bundletool para verificar o alinhamento do ZIP

Para conferir o alinhamento do pacote, use:

bundletool dump config --bundle=<my .aab>  | grep alignment

Se você vir PAGE_ALIGNMENT_16K, isso significa que o pacote solicita o alinhamento do ZIP de 16 kB. Se você vir PAGE_ALIGNMENT_4K, isso instrui o APK criado a partir desse AAB a ter arquivos .so alinhados de 4 KB no arquivo ZIP.

AGP versão 8.5.1 ou mais recente

Dispositivos de 16 KB exigem que os apps enviados com bibliotecas compartilhadas não compactadas as alinhem em um limite de ZIP de 16 KB. Para fazer isso, é necessário fazer upgrade para o Plug-in do Android para Gradle (AGP) versão 8.5.1 ou mais recente. Consulte a seção Assistente de upgrade do Plug-in do Android para Gradle para detalhes sobre o processo de upgrade.

AGP versão 8.5 ou anterior

Se não for possível fazer upgrade do AGP para a versão 8.5.1 ou mais recente, a alternativa é mudar para o uso de bibliotecas compartilhadas compactadas. Atualize a configuração do Gradle para que ele compacte as bibliotecas compartilhadas ao empacotar o app para evitar problemas de instalação com bibliotecas compartilhadas não alinhadas.

Groovy

No arquivo build.gradle, adicione a seguinte opção:

android {
  ...
  packagingOptions {
      jniLibs {
        useLegacyPackaging true
      }
  }
}

Kotlin

No arquivo build.gradle.kts, adicione a seguinte opção:

android {
  ...
  packagingOptions {
      jniLibs {
        useLegacyPackaging = true
      }
  }
}
AGP versão 8.0 ou anterior

Se você estiver usando uma versão do AGP igual ou anterior à 8.0, também será necessário desativar a opção de biblioteca nativa não compactada para pacotes de apps no arquivo gradle.properties:

android.bundle.enableUncompressedNativeLibs=false

Compilar o app usando o alinhamento ELF de 16 KB

Dispositivos de 16 KB exigem que os segmentos ELF das bibliotecas compartilhadas sejam alinhados corretamente usando o alinhamento ELF de 16 KB para que o app seja executado.

Para desenvolvedores de jogos, se o jogo for executado no mecanismo de jogos do Unity, consulte o guia do Unity. Se o jogo for executado no mecanismo de jogos do Unreal, consulte o guia do Unreal. Para mecanismos de jogos nativos, continue com este guia.

Para compilar o app usando o alinhamento ELF de 16 KB, conclua as etapas em uma das seções a seguir, dependendo da versão do Android NDK que você está usando.

Android NDK r28 e versões mais recentes

O NDK versão r28 e mais recentes são compilados com alinhamento de 16 KB por padrão.

Android NDK r27 e versões anteriores

Para oferecer suporte à compilação de bibliotecas compartilhadas alinhadas de 16 KB com o Android NDK versão r27 ou anterior, use as seguintes flags do vinculador:

-Wl,-z,max-page-size=16384
-Wl,-z,common-page-size=16384

Veja como atualizar os arquivos de configuração do sistema de build:

ndk-build

Se você estiver usando o ndk-build, atualize o Android.mk para ativar o alinhamento ELF de 16 KB:

LOCAL_LDFLAGS += -Wl,-z,max-page-size=16384 -Wl,-z,common-page-size=16384

CMake

Se você estiver usando o CMake, atualize o CMakeLists.txt para ativar o alinhamento ELF de 16 KB:

target_link_options(${CMAKE_PROJECT_NAME} PRIVATE
    "-Wl,-z,max-page-size=16384"
    "-Wl,-z,common-page-size=16384"
)

Corrigir o código e resolver problemas de execução

Mesmo que o app esteja alinhado a 16 KB, ele poderá encontrar erros se houver lugares no código que presumam que um dispositivo está usando um tamanho de página específico. Para evitar isso, siga estas etapas:

  1. Remova todas as dependências codificadas que referenciam a PAGE_SIZE constante ou instâncias na lógica de código que presumem que o tamanho da página de um dispositivo é de 4 KB (4096).

    Use getpagesize() ou sysconf(_SC_PAGESIZE).

  2. Procure usos de mmap() e outras APIs que exigem argumentos alinhados à página e substitua por alternativas quando necessário.

Em alguns casos, se o app usar PAGE_SIZE como um valor conveniente que não está vinculado ao tamanho da página subjacente, isso não fará com que o app seja interrompido quando usado no modo de 16 kB. No entanto, se esse valor for transmitido ao kernel com mmap sem MAP_FIXED, o kernel ainda usará uma página inteira, o que desperdiça memória. Por esses motivos, PAGE_SIZE não é definido quando o modo de 16 KB está ativado no NDK r27 e versões mais recentes.

Se o app usa PAGE_SIZE dessa forma e nunca transmite esse valor diretamente ao kernel, em vez de usar PAGE_SIZE, crie uma nova variável com um novo nome para refletir que ela é usada para outras finalidades e não reflete uma página de memória real.

Verificar se os SDKs oferecem suporte a 16 KB

Muitos SDKs são compatíveis com tamanhos de página de 16 KB, principalmente se você os criar ou receber pré-criados recentes. No entanto, como alguns pré-criados ou versões de SDK não são compatíveis com 16 KB, verifique o site de cada provedor de SDK para determinar qual versão usar com 16 KB.

Testar o app em um ambiente de 16 KB

Depois de criar o app com suporte a dispositivos de 16 KB, teste-o em um ambiente de 16 KB para verificar se ele apresenta regressões. Para isso, siga estas etapas:

  1. Configure o SDK do Android 15 ou mais recente.

  2. Configure um dos seguintes ambientes de teste:

  3. Inicie o dispositivo de teste e execute o comando a seguir para verificar se ele está usando um ambiente de 16 KB:

    adb shell getconf PAGE_SIZE
    

    O comando precisa retornar um valor de 16384.

  4. Execute o comando zipalign a seguir para verificar se o app está alinhado a 16 kB, em que APK_NAME é o nome do arquivo APK do app:

    zipalign -c -P 16 -v 4 APK_NAME.apk
    
  5. Teste o app completamente, concentrando-se em áreas que podem ser afetadas por mudança de instâncias de código que referenciam tamanhos de página específicos.

Configurar o Android Emulator com uma imagem do sistema baseada em 16 KB

Para configurar um ambiente de 16 KB usando o Android Emulator, siga estas etapas:

  1. No Android Studio, clique em Tools > SDK Manager.
  2. Na guia SDK Platforms, marque Show Package Details, expanda a seção Android VanillaIceCream ou mais recente e selecione uma ou ambas as imagens do sistema do emulador a seguir, dependendo dos dispositivos virtuais que você quer criar:

    • Google APIs Experimental 16 KB Page Size ARM 64 v8a System Image
    • Google APIs Experimental 16 KB Page Size Intel x86_64 Atom System Image
    Faça o download de imagens do sistema do emulador de 16 KB usando o SDK Manager no
  Android Studio
  3. Clique em Apply > OK para fazer o download das imagens do sistema selecionadas.

  4. Siga as etapas para configurar um dispositivo virtual para o Android 15 e, quando solicitado a selecionar uma imagem do sistema, selecione a imagem do sistema de 16 KB que você fez o download. Se ela não for recomendada automaticamente, você poderá encontrar a imagem do sistema de 16 KB na guia Other Images.

    Encontre a imagem do emulador de 16 KB na guia &quot;Outras imagens&quot;

Iniciar o emulador

Depois de terminar de configurar o Android Emulator e os dispositivos virtuais, inicie o emulador no menu do dispositivo de destino ou na linha de comando.

Ativar o modo 16 KB em um dispositivo usando as opções do desenvolvedor

Ative a opção de desenvolvedor Inicializar com tamanho de página de 16 KB para inicializar um dispositivo no modo de 16 KB.

Nas versões QPR do Android 15, é possível usar a opção do desenvolvedor disponível em alguns dispositivos para inicializar o dispositivo no modo de 16 KB e realizar testes no dispositivo. Antes de usar a opção do desenvolvedor, acesse Configurações > Sistema > Atualizações de software e aplique as atualizações disponíveis.

Essa opção para desenvolvedores está disponível nos seguintes dispositivos:

  • Pixel 8 e 8 Pro (com Android 15 QPR1 ou versões mais recentes)

  • Pixel 8a (com Android 15 QPR1 ou versões mais recentes)

  • Pixel 9, 9 Pro e 9 Pro XL (com Android 15 QPR2 ou versões mais recentes)

  • Pixel 9a (com Android 16 ou versões mais recentes)

Modo de compatibilidade com versões anteriores de 16 KB

Aviso no modo de compatibilidade de tamanho de página

Aviso no modo de compatibilidade de tamanho de página

A opção de compatibilidade com versões anteriores de 16 KB está disponível quando um dispositivo está em execução com um kernel de 16 KB. O gerenciador de pacotes executa um app no modo de compatibilidade com versões anteriores de 16 KB quando as seguintes condições são atendidas:

  • Se o app tiver arquivos ELF (com uma extensão .so) com um alinhamento de segmento LOAD de 4 KB.
  • Se o APK compactado tiver arquivos ELF não compactados que estejam alinhados com ZIP de 4 KB.

Se o gerenciador de pacotes tiver ativado o modo de compatibilidade com versões anteriores de 16 KB para um app, ele vai mostrar um aviso quando for iniciado pela primeira vez, informando que está em execução no modo de compatibilidade com versões anteriores de 16 KB.

O modo de compatibilidade com versões anteriores de 16 KB permite que alguns apps funcionem, mas, para melhor confiabilidade e estabilidade, os apps ainda precisam estar alinhados a 16 KB.

Na página de informações do app, em Advanced, ative ou desative a configuração Run app with page size compat mode para ativar ou desativar o modo de compatibilidade com versões anteriores de 16 KB para um app específico. Essa configuração só fica visível quando o dispositivo está em execução com tamanho de página de 16 KB.

Configuração do modo de compatibilidade de tamanho de página

Configuração do modo de compatibilidade de tamanho de página

Para forçar a compatibilidade com versões anteriores de 16 KB para todos os apps no dispositivo:

adb shell setprop bionic.linker.16kb.app_compat.enabled true
adb shell setprop pm.16kb.app_compat.disabled false

Para forçar a desativação da compatibilidade com versões anteriores de 16 KB para todos os apps no dispositivo:

adb shell setprop bionic.linker.16kb.app_compat.enabled false
adb shell setprop pm.16kb.app_compat.disabled true

No Android 17, também é possível forçar a desativação da compatibilidade com versões anteriores de 16 KB para todos os apps e fazer com que qualquer binário incompatível seja interrompido imediatamente:

    adb shell setprop bionic.linker.16kb.app_compat.enabled fatal
    adb shell setprop pm.16kb.app_compat.disabled true

Defina a propriedade android:pageSizeCompat como ativada ou desativada para ativar ou desativar o modo de compatibilidade com versões anteriores para um app específico no AndroidManifest.xml. Quando essa propriedade é definida, o app não mostra avisos de modo de compatibilidade com versões anteriores quando é iniciado.

Requisito de compatibilidade do Google Play

À medida que os fabricantes de dispositivos equipam os dispositivos com mais RAM para otimizar a performance, muitos vão adotar tamanhos de página maiores, como 16 KB. Para se preparar para o lançamento desses dispositivos futuros, o Google Play está introduzindo um novo requisito de compatibilidade: a partir de 1º de novembro de 2025, todos os novos apps e atualizações de apps enviados ao Google Play e destinados a dispositivos com Android 15 (nível 35 da API) e versões mais recentes precisarão oferecer suporte a tamanhos de página de 16 KB.

Para saber mais sobre esse requisito de compatibilidade, consulte esta postagem do blog.