Fases e desempenho do Compose

Quando o Compose atualiza um frame, ele passa por três fases:

  • Composição:o Compose determina o que mostrar. Ele executa funções combináveis e cria a árvore da interface.
  • Layout:o Compose determina o tamanho e a posição de cada elemento na árvore da interface.
  • Exibição:o Compose renderiza os elementos da interface individuais.

O Compose pode ignorar essas fases de maneira inteligente se elas não forem necessárias. Por exemplo, suponha que um único elemento gráfico alterne entre dois ícones do mesmo tamanho. Como esse elemento não muda de tamanho e nenhum elemento da árvore da interface é adicionado ou removido, o Compose pode pular as fases de composição e layout e redesenhar esse único elemento.

No entanto, erros de programação podem dificultar que o Compose saiba quais fases ele pode ignorar com segurança. Nesse caso, o Compose executa as três fases, o que pode deixar a interface mais lenta. Portanto, muitas das práticas recomendadas de desempenho servem para ajudar o Compose a pular as fases que ele não precisa fazer.

Para saber mais, consulte o guia Fases do Jetpack Compose.

Princípios gerais

Há alguns princípios gerais a serem seguidos que podem melhorar a performance em geral:

  • Sempre que possível, remova os cálculos das funções combináveis. As funções combináveis podem precisar ser executadas novamente sempre que a interface mudar. Todo código que você colocar no elemento combinável será executado novamente, possivelmente para cada frame de uma animação. Limite o código do elemento combinável apenas ao necessário para criar a interface.
  • Adie as leituras de estado pelo maior tempo possível. Ao mover a leitura de estado para um elemento combinável ou uma fase posterior, você pode minimizar a recomposição ou pular completamente a fase de composição. Você pode fazer isso transmitindo funções lambda em vez do valor do estado para mudar o estado com frequência e preferindo modificadores baseados em lambda ao transmitir estados com mudanças frequentes. Confira um exemplo dessa técnica na seção Adiar leituras pelo maior tempo possível do artigo Seguir as práticas recomendadas.

Outros recursos