Ler em inglês

Compartilhar via


Enumerable.OfType<TResult>(IEnumerable) Método

Definição

Filtra os elementos de um IEnumerable com base em um tipo especificado.

C#
public static System.Collections.Generic.IEnumerable<TResult> OfType<TResult> (this System.Collections.IEnumerable source);

Parâmetros de tipo

TResult

O tipo no qual filtrar os elementos da sequência.

Parâmetros

source
IEnumerable

O IEnumerable cujos elementos serão filtrados.

Retornos

IEnumerable<TResult>

Um IEnumerable<T> que contém elementos da sequência de entrada de tipo TResult.

Exceções

source é null.

Exemplos

O exemplo de código a seguir demonstra como usar OfType para filtrar os elementos de um IEnumerable.

C#
System.Collections.ArrayList fruits = new()
{
    "Mango",
    "Orange",
    null,
    "Apple",
    3.0,
    "Banana"
};

// Apply OfType() to the ArrayList.
IEnumerable<string> query1 = fruits.OfType<string>();

Console.WriteLine("Elements of type 'string' are:");
foreach (string fruit in query1)
{
    Console.WriteLine(fruit);
}

// The following query shows that the standard query operators such as
// Where() can be applied to the ArrayList type after calling OfType().
IEnumerable<string> query2 =
    fruits.OfType<string>().Where(fruit =>
    fruit.Contains('n', StringComparison.CurrentCultureIgnoreCase));

Console.WriteLine("\nThe following strings contain 'n':");
foreach (string fruit in query2)
{
    Console.WriteLine(fruit);
}

// This code produces the following output:
//
// Elements of type 'string' are:
// Mango
// Orange
// Apple
// Banana
//
// The following strings contain 'n':
// Mango
// Orange
// Banana

Comentários

Esse método é implementado usando a execução adiada. O valor retornado imediato é um objeto que armazena todas as informações necessárias para executar a ação. A consulta representada por esse método não é executada até que o objeto seja enumerado chamando seu GetEnumerator método diretamente ou usando foreach em C# ou For Each no Visual Basic.

O OfType<TResult>(IEnumerable) método retorna apenas os elementos em source que não são nulos e compatíveis com o tipo TResult. Para receber uma exceção se um elemento não puder ser convertido no tipo TResult, use Cast<TResult>(IEnumerable).

Esse método é um dos poucos métodos de operador de consulta padrão que podem ser aplicados a uma coleção que tem um tipo não parametrizado, como um ArrayList. Isso ocorre porque OfType estende o tipo IEnumerable. OfType não pode ser aplicado somente a coleções baseadas no tipo parametrizado IEnumerable<T> , mas também coleções baseadas no tipo não parametrizado IEnumerable .

Aplicando-se OfType a uma coleção que implementa IEnumerable, você obtém a capacidade de consultar a coleção usando os operadores de consulta padrão. Por exemplo, especificar um argumento de tipo de Object para OfType retornaria um objeto do tipo IEnumerable<Object> em C# ou IEnumerable(Of Object) no Visual Basic, ao qual os operadores de consulta padrão podem ser aplicados.

Aplica-se a

Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0