Enumerable.OfType<TResult>(IEnumerable) Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Filtra os elementos de um IEnumerable com base num tipo especificado.
public:
generic <typename TResult>
[System::Runtime::CompilerServices::Extension]
static System::Collections::Generic::IEnumerable<TResult> ^ OfType(System::Collections::IEnumerable ^ source);
public static System.Collections.Generic.IEnumerable<TResult> OfType<TResult>(this System.Collections.IEnumerable source);
static member OfType : System.Collections.IEnumerable -> seq<'Result>
<Extension()>
Public Function OfType(Of TResult) (source As IEnumerable) As IEnumerable(Of TResult)
Parâmetros de Tipo Genérico
- TResult
O tipo para filtrar os elementos da sequência em.
Parâmetros
- source
- IEnumerable
Os IEnumerable elementos de quem filtrar.
Devoluções
E IEnumerable<T> que contém elementos da sequência de entrada do tipo TResult.
Exceções
source é null.
Exemplos
O exemplo de código seguinte demonstra como usar OfType para filtrar os elementos de um IEnumerable.
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
' Create an ArrayList and add items to it.
Dim fruits As New ArrayList() From {
"Mango",
"Orange",
Nothing,
"Apple",
3.0,
"Banana"
}
' Apply OfType(Of String)() to the ArrayList
' to filter out non-string items.
Dim query1 As IEnumerable(Of String) = fruits.OfType(Of String)()
' Print the results.
Dim output As New System.Text.StringBuilder("Elements of type 'string' are:" _
& vbCrLf)
For Each fruit As String In query1
output.AppendLine(fruit)
Next
' The following query shows that the standard query operators such as
' Where() can be applied to the ArrayList type after calling OfType().
Dim query2 As IEnumerable(Of String) =
fruits.OfType(Of String)().Where(Function(fruit) _
fruit.Contains("n"c, StringComparison.CurrentCultureIgnoreCase))
output.AppendLine(vbCrLf & "The following strings contain 'n':")
For Each fruit As String In query2
output.AppendLine(fruit)
Next
' Display the output.
Console.WriteLine(output.ToString())
' This code produces the following output:
'
' Elements of type 'string' are:
' Mango
' Orange
' Apple
' Banana
'
' The following strings contain 'n':
' Mango
' Orange
' Banana
Observações
Este método é implementado através da execução diferida. O valor de retorno imediato é um objeto que armazena toda a informação necessária para realizar a ação. A consulta representada por este método não é executada até que o objeto seja enumerado, seja chamando diretamente o seu método GetEnumerator ou usando foreach em C# ou For Each em Visual Basic.
O OfType<TResult>(IEnumerable) método devolve apenas aqueles elementos em source que são não nulos e compatíveis com o tipo TResult. Para receber uma exceção se um elemento não puder ser castado para o tipo TResult, use Cast<TResult>(IEnumerable).
Este método é um dos poucos métodos padrão de operadores de consulta que podem ser aplicados a uma coleção que tem um tipo não parametrizado, como um ArrayList. Isto deve-se ao facto de OfType estender o tipo IEnumerable. OfType não podem ser aplicadas apenas a coleções baseadas no tipo parametrizado IEnumerable<T> , mas também a coleções baseadas no tipo não parametrizado IEnumerable .
Ao aplicar OfType a uma coleção que implementa IEnumerable, ganha a capacidade de consultar a coleção usando os operadores padrão de consulta. Por exemplo, especificar um argumento de tipo Object para OfType retornaria um objeto do tipo IEnumerable<Object> em C# ou IEnumerable(Of Object) em Visual Basic, ao qual os operadores padrão de consulta podem ser aplicados.