Enumerable.OfType<TResult>(IEnumerable) メソッド

定義

指定された型に基づいて IEnumerable の要素をフィルター処理します。

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)

型パラメーター

TResult

シーケンスの要素をフィルター処理する型。

パラメーター

source
IEnumerable

フィルター処理する要素を含む IEnumerable

戻り値

IEnumerable<TResult>

TResult 型の入力シーケンスの要素を格納する IEnumerable<T>

例外

sourcenullです。

次のコード例は、を使用しての要素をフィルター処理する方法を示して OfType 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.
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

注釈

このメソッドは、遅延実行を使用して実装されます。 イミディエイトの戻り値は、アクションを実行するために必要なすべての情報を格納するオブジェクトです。 か、呼び出すことによって、オブジェクトが列挙されるまで、このメソッドによって表されるクエリは実行されません、GetEnumeratorメソッドを使用して直接またはforeachVisual C# またはFor EachVisual Basic で。

メソッドは、 OfType<TResult>(IEnumerable) 型にキャストできる内の要素のみを返し source TResult ます。 代わりに、要素を型にキャストできない場合に例外を受け取るには TResult 、を使用し Cast<TResult>(IEnumerable) ます。

このメソッドは、など、パラメーター化されていない型を持つコレクションに適用できる、いくつかの標準クエリ演算子メソッドの1つです ArrayList 。 これは、によっ OfType て型が拡張されるためです IEnumerableOfType パラメーター化された型に基づくコレクションにのみ適用でき IEnumerable<T> ますが、パラメーター化されていない型に基づくコレクションにも適用でき IEnumerable ます。

を実装するコレクションにを適用することによって OfType IEnumerable 、標準クエリ演算子を使用してコレクションに対してクエリを実行できるようになります。 たとえば、に型引数を指定する Object OfType と、C# では型のオブジェクトが返され、 IEnumerable<Object> IEnumerable(Of Object) Visual Basic では標準クエリ演算子を適用することができます。

適用対象