Classificação de operadores de consulta padrão pelo modo de execução
O LINQ a objetos implementações dos métodos de operador de consulta padrão é executado em uma das duas maneiras principais: imediata ou adiada. Os operadores de consulta que usam a execução retardada Além disso podem ser divididos em duas categorias: fluxo contínuo e não-streaming. Se você souber como executar os operadores de consulta diferentes, ele pode ajudá-lo a compreender os resultados que você obtiver de uma determinada consulta. Isso é especialmente verdadeiro se a alteração da fonte de dados ou se você estiver criando uma consulta em cima de outra consulta. Este tópico classifica os operadores de consulta padrão de acordo com a sua maneira de execução.
Maneiras de execução
Imediata
Execução imediata significa que a fonte de dados é lido e a operação é executada no momento em que o código onde a consulta é declarada. Todos os operadores de consulta padrão retornam um resultado único, não enumerable executar imediatamente.
Foi adiado
Execução retardada significa que a operação não é executada no momento em que o código onde a consulta é declarada. A operação é executada somente quando a variável de consulta é enumerada, por exemplo, usando um foreach (For Each na Visual Basic) instrução. Isso significa que os resultados da execução da consulta dependem do conteúdo da fonte de dados quando a consulta é executada em vez de quando a consulta é definida. Se a variável de consulta é enumerada várias vezes, os resultados podem diferir de cada vez. Quase todos os operadores de consulta padrão cujo tipo de retorno é IEnumerable<T> ou IOrderedEnumerable<TElement> executar em uma maneira adiada.
Operadores de consulta que usam a execução retardada Além disso podem ser classificadas como streaming ou não streaming.
Streaming
Operadores de streaming não tem ler os dados de origem antes de eles produzem elementos. Em tempo de execução, um operador de fluxo executa sua operação em cada elemento de origem, como ele é lido e produz o elemento se apropriado. Um operador de streaming continua a ler os elementos de origem até que um elemento de resultado pode ser produzido. Isso significa que mais de um elemento de origem pode ser lido para produzir um elemento de resultado.
Não Streaming.
Operadores de fluxo contínuo não devem ler os dados de origem, antes que elas podem produzir um elemento de resultado. Operações como, por exemplo, classificação ou agrupamento se encaixam nessa categoria. No momento da execução, operadores de consulta de streaming não ler os dados de origem, colocá-lo em uma estrutura de dados, executam a operação e produzem os elementos resultantes.
Tabela de classificação
A tabela a seguir classifica cada método do operador de consulta padrão de acordo com a seu método de execução.
Observação |
---|
Se um operador é marcado em duas colunas, duas seqüências de entrada estão envolvidas na operação e cada seqüência é avaliada de maneira diferente. Nesses casos, é sempre a primeira seqüência na lista de parâmetros, o que é avaliada em adiada, streaming de maneira. |
Operador de consulta padrão |
Tipo de retorno |
Execução imediata |
Adiar a execução de fluxo contínuo |
Adiar a execução não Streaming |
---|---|---|---|---|
TSource |
X |
|
|
|
X |
|
|
||
X |
|
|
||
|
X |
|
||
Único valor numérico |
X |
|
|
|
|
X |
|
||
|
X |
|
||
X |
|
|
||
X |
|
|
||
|
X |
|
||
|
X |
|
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
X |
|
|
||
|
X |
X |
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
|
|
X |
||
|
X |
X |
||
|
X |
X |
||
|
X |
X |
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
X |
|
|
||
Único valor numérico, TSource ou TResult |
X |
|
|
|
Único valor numérico, TSource ou TResult |
X |
|
|
|
|
X |
|
||
|
|
X |
||
|
|
X |
||
|
X |
|
||
|
X |
|
||
|
|
X |
||
|
X |
|
||
|
X |
|
||
X |
|
|
||
TSource |
X |
|
|
|
TSource |
X |
|
|
|
|
X |
|
||
|
X |
|
||
Único valor numérico |
X |
|
|
|
|
X |
|
||
|
X |
|
||
|
|
X |
||
|
|
X |
||
Matriz de TSource |
X |
|
|
|
X |
|
|
||
X |
|
|
||
X |
|
|
||
|
X |
|
||
|
X |
|
Consulte também
Referência
Conceitos
Visão geral operadores de consulta padrão
Sintaxe de expressão de consulta para operadores de consulta padrão