Função Concurrent no Power Apps

Avalia múltiplas fórmulas em simultâneo.

Descrição

A função Concurrent avalia múltiplas fórmulas ao mesmo tempo. Normalmente, quanto temos múltiplas fórmulas, as mesmas são avaliadas ao serem encadeadas com o operador ; que avalia cada fórmula sequencialmente por ordem. Quando a aplicação executa operações em simultâneo, os utilizadores esperam menos tempo pelo mesmo resultado.

Na propriedade OnStart da sua aplicação, utilize Concurrent para melhorar o desempenho quando a aplicação carrega dados. Quando as chamadas de dados não são iniciadas até as chamadas anteriores serem concluídas, a aplicação tem de aguardar pela soma de todos os tempos de pedidos. Se as chamadas de dados forem iniciadas ao mesmo tempo, a aplicação só precisa de esperar pelo tempo do pedido mais longo. O desempenho dos browsers é muitas vezes melhorado ao executar operações de dados em simultâneo.

Não é possível prever a ordem pela qual as fórmulas dentro da função Concurrent são avaliadas. As fórmulas dentro da função Concurrent não devem conter dependências de outras fórmulas dentro da mesma função Concurrent. Se tal acontecer, o Power Apps apresentará um erro. Nessa função, pode utilizar dependências de fórmulas fora da função Concurrent com segurança porque as mesmas serão concluídas antes de a função Concurrent ser iniciada. As fórmulas depois da função Concurrent podem utilizar dependências de fórmulas dentro da função: todas serão concluídas antes de a função Concurrent terminar e passar para a próxima fórmula na cadeia (se utilizar o operador ;). Fique atento a dependências de ordens subtis se estiver a chamar métodos de serviço ou funções que tenham efeitos secundários.

Pode encadear fórmulas com o operador ; dentro de um argumento para Concurrent. Por exemplo, Concurrent( Set( a; 1 ); Set( b; a+1 ); Set( x; 2 ); Set( y; x+2 ) ) avalia Set( a; 1 ); Set( b; a+1 ) e Set( x; 2 ); Set( y; x+2 ) em simultâneo. Neste caso, as dependências dentro das fórmulas podem ser utilizadas: a será definida antes de b e x será definida antes de y.

Consoante o dispositivo ou browser em que a aplicação esteja a ser executada, apenas algumas fórmulas poderão ser avaliadas em simultâneo. A função Concurrent utiliza as funcionalidades disponíveis e não será concluída até todas as fórmulas serem avaliadas.

Se ativar a opção Gestão de erros ao nível da fórmula (nas definições avançadas), o primeiro erro encontrado na ordem dos argumentos será devolvido da função Concurrent. Caso contrário, será devolvida a indicação blank. Se todas as fórmulas forem avaliadas com êxito, será devolvida a indicação true. Se a avaliação de uma fórmula falhar, o resto dessa fórmula será interrompido, mas as outras fórmulas continuarão a ser avaliadas.

Só pode utilizar a função Concurrent em fórmulas de comportamento.

Sintaxe

Concurrent( Fórmula1; Fórmula2 [; ...] )

  • Fórmula(s) – Obrigatório. Fórmulas a avaliar em simultâneo. Tem de fornecer pelo menos duas fórmulas.

Exemplos

Carregar dados mais rapidamente

  1. Crie uma aplicação e adicione quatro origens de dados do Microsoft Dataverse, SQL Server ou SharePoint.

    Este exemplo utiliza quatro tabelas a partir da base de dados de exemplo da Adventure Works no SQL Azure. Depois de criar a base de dados, ligue-se à mesma a partir do Power Apps com o nome de servidor completamente qualificado (por exemplo, srvname.database.windows.net):

    Ligar à base de dados da Adventure Works no Azure

  2. Adicione um controlo Botão e defina a respetiva propriedade OnSelect para esta fórmula:

    ClearCollect( Product, '[SalesLT].[Product]' );
    ClearCollect( Customer, '[SalesLT].[Customer]' );
    ClearCollect( SalesOrderDetail, '[SalesLT].[SalesOrderDetail]' ); 
    ClearCollect( SalesOrderHeader, '[SalesLT].[SalesOrderHeader]' )
    
  3. No Microsoft Edge ou no Google Chrome, ative as ferramentas de programador para controlar o tráfego de rede enquanto a aplicação é executada.

  4. (opcional) Ative a limitação de rede para exagerar os efeitos desta comparação.

  5. Selecione o botão enquanto mantém a tecla Alt premida e, em seguida, observe o tráfego de rede.

    As ferramentas mostram quatro pedidos efetuados em série, semelhante a este exemplo. Os tempos reais foram removidos pois irão variar muito. O gráfico mostra que cada chamada é iniciada após a última chamada ser concluída:

    Gráfico de tempo de quatro pedidos de rede, em que cada um deles é iniciado depois de o último ser concluído, abrangendo todo o período de tempo

  6. Guarde, feche e abra novamente a aplicação.

    Como o Power Apps coloca dados em cache, selecionar novamente o botão não causa necessariamente quatro novos pedidos. Sempre que quiser testar o desempenho, feche e abra novamente a sua aplicação. Se tiver ativado a limitação de rede, recomenda-se que a desative até estar pronto para outro teste.

  7. Adicione um segundo controlo Botão e defina a respetiva propriedade OnSelect a esta fórmula:

    Concurrent( 
        ClearCollect( Product, '[SalesLT].[Product]' ), 
        ClearCollect( Customer, '[SalesLT].[Customer]' ),
        ClearCollect( SalesOrderDetail, '[SalesLT].[SalesOrderDetail]' ),
        ClearCollect( SalesOrderHeader, '[SalesLT].[SalesOrderHeader]' )
    )
    

    Tenha em atenção que adicionou as mesmas chamadas ClearCollect ao primeiro botão, mas as mesmas estão agora dentro da função Concurrent e separadas por ponto e vírgulas.

  8. Limpe o monitor de rede no browser.

  9. Se estava a utilizar a limitação de rede, ative-a novamente.

  10. Selecione o segundo botão enquanto mantém a tecla Alt premida e, em seguida, observe o tráfego de rede.

    As ferramentas mostram quatro pedidos efetuados em simultâneo, semelhante a este exemplo. Novamente, os tempos reais foram removidos pois irão variar muito. O gráfico mostra que todas as chamadas são iniciadas praticamente ao mesmo tempo e que não esperam pela conclusão da anterior:

    Gráfico de tempo de quatro pedidos de rede, em que os quatro são iniciados em conjunto, abrangendo cerca de metade do período de tempo

    Estes gráficos baseiam-se na mesma escala. Com a função Concurrent, conseguiu reduzir o tempo total de conclusão destas operações para metade.

  11. Guarde, feche e abra novamente a aplicação.

Condição race

  1. Adicione uma ligação para o serviço Microsoft Translator à sua aplicação.

  2. Adicione um controlo Entrada de texto e mude o respetivo nome para EntradaDeTexto1 se tiver um nome diferente.

  3. Adicione um controlo Botão e defina a respetiva propriedade OnSelect para esta fórmula:

    Set( StartTime, Value( Now() ) );
    Concurrent(
        Set( FRTrans, MicrosoftTranslator.Translate( TextInput1.Text, "fr" ) ); 
            Set( FRTransTime, Value( Now() ) ),
        Set( DETrans, MicrosoftTranslator.Translate( TextInput1.Text, "de" ) ); 
            Set( DETransTime, Value( Now() ) )
    );
    Collect( Results,
        { 
            Input: TextInput1.Text,
            French: FRTrans, FrenchTime: FRTransTime - StartTime, 
            German: DETrans, GermanTime: DETransTime - StartTime, 
            FrenchFaster: FRTransTime < DETransTime
        }
    )
    
  4. Adicione um controlo Tabela de dados e defina a respetiva propriedade Items para Resultados.

  5. No separador Propriedades do painel direito, selecione Editar campos para abrir o painel Campos.

  6. Na lista de campos, selecione a caixa de verificação de cada campo para os apresentar todos na tabela de dados.

  7. (opcional) Arraste o campo Entrada para a parte superior da lista e arraste o campo FrancêsMaisRápido para a parte inferior da lista.

    Lista de campos na coleção de Resultados

  8. No controlo Entrada de texto, escreva ou cole uma frase para traduzir.

  9. Mantenha a tecla Alt premida e selecione o botão múltiplas vezes para preencher a tabela.

    Os tempos são apresentados em milissegundos.

    Apresentação da tabela de dados com os resultados da tradução da cadeia "Hello World" para francês e alemão. Por vezes, a tradução para francês é mais rápida do que para alemão e, por vezes, acontece o contrário.

    Em alguns casos, a tradução para francês é mais rápida do que a tradução para alemão e vice-versa. Ambas começam ao mesmo tempo, mas uma é concluída antes da outra por diversos motivos, incluindo a latência de rede e o processamento do lado do servidor.

    Uma condição race ocorreria se a aplicação dependesse de uma tradução terminar primeiro. Felizmente, o Power Apps sinaliza a maioria das dependências de tempo que consegue detetar.

Nota

Pode indicar-nos as suas preferências no que se refere ao idioma da documentação? Responda a um breve inquérito. (tenha em atenção que o inquérito está em inglês)

O inquérito irá demorar cerca de sete minutos. Não são recolhidos dados pessoais (declaração de privacidade).