Classificação de operadores de consulta padrão pelo modo de execução

The LINQ para objetos de implementações de métodos de operadores de consulta padrão executar de duas maneiras principais: imediata ou adiada.Os operadores de consulta que usa 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 ajudar compreender os resultados que você obtiver de uma determinada consulta.Isso é especialmente verdadeiro se a fonte de dados está mudando ou se você estiver criando uma consulta de outra consulta.Este tópico classifica os operadores de consulta padrão de acordo com sua maneira de execução.

Maneiras de execução

Imediata

Execução imediata significa que a fonte de dados é lidos e a operação é executada no ponto de código onde a consulta é declarada.Todos os operadores de consulta padrão que retornam um resultado único e não enumerável executar imediatamente.

Foi adiado

Execução retardada significa que não é executar a operação no ponto de 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 em Visual Basic) demonstrativo. Isso significa que os resultados da execução da consulta dependem do Sumário 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 ser diferentes cada vez. Quase todos os operadores de consulta padrão cujo tipo de retorno é IEnumerable<T> ou IOrderedEnumerable<TElement> executar na maneira adiada.

Operadores de consulta que usa a execução retardada Além disso podem ser classificados sistema autônomo streaming ou streaming não.

streaming

Operadores de streaming não são necessário ler todos os dados de fonte antes que eles produzem elementos.Ao time de execução, um operador de streaming executa sua operação em cada elemento de fonte sistema autônomo ele é lido e gera o elemento se apropriado.Um operador de streaming continua a ler os elementos de fonte até que um elemento de resultado pode ser produzido.Isso significa que mais de um elemento de fonte pode ser lido para produzir um elemento de resultado.

Não Streaming

Operadores de streaming não devem ler os dados de fonte antes que eles possam gerar um elemento de resultado.Operações sistema autônomo classificação ou agrupamento se encaixam nessa categoria.Ao time de execução, operadores de consulta de streaming não ler os dados de fonte, colocá-lo em uma estrutura de dados, executar a operação e produzem 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 i s marcado em duas colunas, dois entrada seqüências são envolvidos na operação e cada sequência é avaliada diferente .Nesses casos, ele é sempre a primeira sequência na lista de parâmetros que é avaliada em um adiada, streaming forma .

Operador de consulta padrão

Tipo de retorno

Execução imediata

Adiar execução streaming

Adiar execução não Streaming

Aggregate

TSource

X

 

 

All<TSource>

Boolean

X

 

 

Any

Boolean

X

 

 

AsEnumerable<TSource>

IEnumerable<T>

X

 

Average

Único valor numérico

X

 

 

Cast<TResult>

IEnumerable<T>

 

X

 

Concat<TSource>

IEnumerable<T>

 

X

 

Contains

Boolean

X

 

 

Count

Int32

X

 

 

DefaultIfEmpty

IEnumerable<T>

 

X

 

Distinct

IEnumerable<T>

 

X

 

ElementAt<TSource>

TSource

X

 

 

ElementAtOrDefault<TSource>

TSource

X

 

 

Empty<TResult>

IEnumerable<T>

X

 

 

Except

IEnumerable<T>

X

X

First

TSource

X

 

 

FirstOrDefault

TSource

X

 

 

GroupBy

IEnumerable<T>

 

 

X

GroupJoin

IEnumerable<T>

X

X

Intersect

IEnumerable<T>

X

X

Join

IEnumerable<T>

X

X

Last

TSource

X

 

 

LastOrDefault

TSource

X

 

 

LongCount

Int64

X

 

 

Max

Único valor numérico, TSource ou TResult

X

 

 

Min

Único valor numérico, TSource ou TResult

X

 

 

OfType<TResult>

IEnumerable<T>

 

X

 

OrderBy

IOrderedEnumerable<TElement>

 

 

X

OrderByDescending

IOrderedEnumerable<TElement>

 

 

X

Range

IEnumerable<T>

 

X

 

Repeat<TResult>

IEnumerable<T>

 

X

 

Reverse<TSource>

IEnumerable<T>

 

 

X

Select

IEnumerable<T>

 

X

 

SelectMany

IEnumerable<T>

 

X

 

SequenceEqual

Boolean

X

 

 

Single

TSource

X

 

 

SingleOrDefault

TSource

X

 

 

Skip<TSource>

IEnumerable<T>

 

X

 

SkipWhile

IEnumerable<T>

 

X

 

Sum

Único valor numérico

X

 

 

Take<TSource>

IEnumerable<T>

 

X

 

TakeWhile

IEnumerable<T>

 

X

 

ThenBy

IOrderedEnumerable<TElement>

 

 

X

ThenByDescending

IOrderedEnumerable<TElement>

 

 

X

ToArray<TSource>

Matriz TSource

X

 

 

ToDictionary

Dictionary<TKey, TValue>

X

 

 

ToList<TSource>

IList<T>

X

 

 

ToLookup

ILookup<TKey, TElement>

X

 

 

Union

IEnumerable<T>

 

X

 

Where

IEnumerable<T>

 

X

 

Consulte também

Conceitos

Visão geral de operadores de consulta padrão

Sintaxe de expressão de consulta para operadores de consulta padrão

LINQ para Objetos

Referência

Enumerable