Enumerable.OfType<TResult>(IEnumerable) Metodo

Definizione

Filtra gli elementi di un oggetto IEnumerable in base a un tipo specificato.Filters the elements of an IEnumerable based on a specified type.

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)

Parametri di tipo

TResult

Il tipo in base al quale filtrare gli elementi della sequenza.The type to filter the elements of the sequence on.

Parametri

source
IEnumerable

L’oggetto IEnumerable i cui elementi devono essere filtrati.The IEnumerable whose elements to filter.

Restituisce

IEnumerable<TResult>

Oggetto IEnumerable<T> che contiene elementi della sequenza di input del tipo TResult.An IEnumerable<T> that contains elements from the input sequence of type TResult.

Eccezioni

source è null.source is null.

Esempi

Nell'esempio di codice riportato di seguito viene illustrato come utilizzare OfType per filtrare gli elementi di un IEnumerable.The following code example demonstrates how to use OfType to filter the elements of an IEnumerable.

System.Collections.ArrayList fruits = new System.Collections.ArrayList(4);
fruits.Add("Mango");
fruits.Add("Orange");
fruits.Add("Apple");
fruits.Add(3.0);
fruits.Add("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.ToLower().Contains("n"));

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 System.Collections.ArrayList(4)
fruits.Add("Mango")
fruits.Add("Orange")
fruits.Add("Apple")
fruits.Add(3.0)
fruits.Add("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.ToLower().Contains("n"))

output.AppendLine(vbCrLf & "The following strings contain 'n':")
For Each fruit As String In query2
    output.AppendLine(fruit)
Next

' Display the output.
MsgBox(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

Commenti

Questo metodo viene implementato tramite l'esecuzione posticipata.This method is implemented by using deferred execution. Il valore restituito immediato è un oggetto che archivia tutte le informazioni necessarie per eseguire l'azione.The immediate return value is an object that stores all the information that is required to perform the action. La query rappresentata da questo metodo non viene eseguita finché l'oggetto non viene enumerato chiamando il relativo metodo GetEnumerator direttamente o utilizzando foreach in Visual C# o For Each in Visual Basic.The query represented by this method is not executed until the object is enumerated either by calling its GetEnumerator method directly or by using foreach in Visual C# or For Each in Visual Basic.

Il metodo OfType<TResult>(IEnumerable) restituisce solo gli elementi source di cui è possibile eseguire il cast al tipo TResult.The OfType<TResult>(IEnumerable) method returns only those elements in source that can be cast to type TResult. Per ricevere invece un'eccezione se non è possibile eseguire il cast di un elemento al tipo TResult, utilizzare Cast<TResult>(IEnumerable).To instead receive an exception if an element cannot be cast to type TResult, use Cast<TResult>(IEnumerable).

Questo metodo è uno dei pochi metodi dell'operatore query standard che è possibile applicare a una raccolta con un tipo senza parametri, ad esempio un ArrayList.This method is one of the few standard query operator methods that can be applied to a collection that has a non-parameterized type, such as an ArrayList. Questo perché OfType estende il tipo IEnumerable.This is because OfType extends the type IEnumerable. OfType non può essere applicato solo a raccolte basate sul tipo IEnumerable<T> con parametri, ma anche raccolte basate sul tipo di IEnumerable senza parametri.OfType cannot only be applied to collections that are based on the parameterized IEnumerable<T> type, but collections that are based on the non-parameterized IEnumerable type also.

Applicando OfType a una raccolta che implementa IEnumerable, è possibile eseguire una query sulla raccolta usando gli operatori di query standard.By applying OfType to a collection that implements IEnumerable, you gain the ability to query the collection by using the standard query operators. Se ad esempio si specifica un argomento di tipo Object per OfType, viene restituito un oggetto di tipo @no__t- C# 2 in o IEnumerable(Of Object) in Visual Basic, a cui è possibile applicare gli operatori di query standard.For example, specifying a type argument of Object to OfType would return an object of type IEnumerable<Object> in C# or IEnumerable(Of Object) in Visual Basic, to which the standard query operators can be applied.

Si applica a