Leer en inglés

Compartir vía


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

Definición

Filtra los elementos de IEnumerable en función de un tipo especificado.

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

Parámetros de tipo

TResult

El tipo según el cual se van a filtrar los elementos de la secuencia.

Parámetros

source
IEnumerable

IEnumerable cuyos elementos se van a filtrar.

Devoluciones

IEnumerable<TResult>

Una interfaz IEnumerable<T> que contiene los elementos de la secuencia de entrada de tipo TResult.

Excepciones

source es null.

Ejemplos

En el ejemplo de código siguiente se muestra cómo usar OfType para filtrar los elementos de .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

Comentarios

Este método se implementa mediante la ejecución diferida. El valor devuelto inmediato es un objeto que almacena toda la información necesaria para realizar la acción. La consulta representada por este método no se ejecuta hasta que el objeto se enumera llamando directamente a su GetEnumerator método o mediante foreach en C# o For Each en Visual Basic.

El OfType<TResult>(IEnumerable) método devuelve solo los elementos de source que no son NULL y son compatibles con el tipo TResult. Para recibir una excepción si un elemento no se puede convertir al tipo TResult, use Cast<TResult>(IEnumerable).

Este método es uno de los pocos métodos de operador de consulta estándar que se pueden aplicar a una colección que tiene un tipo no parametrizado, como .ArrayList Esto se debe a que OfType extiende el tipo IEnumerable. OfType no solo se puede aplicar a las colecciones que se basan en el tipo con parámetros IEnumerable<T> , sino que también se basan en el tipo no parametrizado IEnumerable .

Al aplicar OfType a una colección que implementa IEnumerable, obtiene la capacidad de consultar la colección mediante los operadores de consulta estándar. Por ejemplo, especificar un argumento de tipo de Object para OfType devolvería un objeto de tipo IEnumerable<Object> en C# o IEnumerable(Of Object) en Visual Basic, al que se pueden aplicar los operadores de consulta estándar.

Se aplica a

Producto Versiones
.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