MethodInfo.GetGenericArguments メソッド

定義

ジェネリック メソッドの型引数、またはジェネリック メソッドの定義の型パラメーターを表す Type オブジェクトの配列を返します。Returns an array of Type objects that represent the type arguments of a generic method or the type parameters of a generic method definition.

public:
 override cli::array <Type ^> ^ GetGenericArguments();
public override Type[] GetGenericArguments ();
[System.Runtime.InteropServices.ComVisible(true)]
public override Type[] GetGenericArguments ();
override this.GetGenericArguments : unit -> Type[]
[<System.Runtime.InteropServices.ComVisible(true)>]
override this.GetGenericArguments : unit -> Type[]
Public Overrides Function GetGenericArguments () As Type()

戻り値

Type[]

ジェネリック メソッドの型引数またはジェネリック メソッド定義の型パラメーターを表す Type オブジェクトの配列。An array of Type objects that represent the type arguments of a generic method or the type parameters of a generic method definition. 現在のメソッドがジェネリック メソッドではない場合は、空の配列を返します。Returns an empty array if the current method is not a generic method.

属性

例外

このメソッドはサポートされていません。This method is not supported.

次のコード例は、ジェネリックメソッドの型引数を取得して表示する方法を示しています。The following code example shows how to get the type arguments of a generic method and display them.

この例は、メソッドに提供されているより大きな例の一部です MakeGenericMethodThis example is part of a larger example provided for the MakeGenericMethod method.

// If this is a generic method, display its type arguments.
//
if (mi->IsGenericMethod)
{
    array<Type^>^ typeArguments = mi->GetGenericArguments();

    Console::WriteLine("\tList type arguments ({0}):", 
        typeArguments->Length);

    for each (Type^ tParam in typeArguments)
    {
        // IsGenericParameter is true only for generic type
        // parameters.
        //
        if (tParam->IsGenericParameter)
        {
            Console::WriteLine("\t\t{0}  parameter position {1}" +
                "\n\t\t   declaring method: {2}",
                tParam,
                tParam->GenericParameterPosition,
                tParam->DeclaringMethod);
        }
        else
        {
            Console::WriteLine("\t\t{0}", tParam);
        }
    }
}
// If this is a generic method, display its type arguments.
//
if (mi.IsGenericMethod)
{
    Type[] typeArguments = mi.GetGenericArguments();

    Console.WriteLine("\tList type arguments ({0}):",
        typeArguments.Length);

    foreach (Type tParam in typeArguments)
    {
        // IsGenericParameter is true only for generic type
        // parameters.
        //
        if (tParam.IsGenericParameter)
        {
            Console.WriteLine("\t\t{0}  parameter position {1}" +
                "\n\t\t   declaring method: {2}",
                tParam,
                tParam.GenericParameterPosition,
                tParam.DeclaringMethod);
        }
        else
        {
            Console.WriteLine("\t\t{0}", tParam);
        }
    }
}
' If this is a generic method, display its type arguments.
'
If mi.IsGenericMethod Then
    Dim typeArguments As Type() = mi.GetGenericArguments()
    
    Console.WriteLine(vbTab & "List type arguments ({0}):", _
        typeArguments.Length)
    
    For Each tParam As Type In typeArguments
        ' IsGenericParameter is true only for generic type
        ' parameters.
        '
        If tParam.IsGenericParameter Then
            Console.WriteLine(vbTab & vbTab _
                & "{0}  parameter position: {1}" _
                & vbCrLf & vbTab & vbTab _
                & "   declaring method: {2}", _
                tParam,  _
                tParam.GenericParameterPosition, _
                tParam.DeclaringMethod)
        Else
            Console.WriteLine(vbTab & vbTab & tParam.ToString())
        End If
    Next tParam
End If

注釈

返された配列の要素は、ジェネリックメソッドの型パラメーターのリストに出現する順序に従っています。The elements of the returned array are in the order in which they appear in the list of type parameters for the generic method.

  • 現在のメソッドが閉じて構築されたメソッド (つまり、 ContainsGenericParameters プロパティがを返す) の場合 false 、メソッドによって返される配列には、 GetGenericArguments ジェネリックメソッド定義のジェネリック型パラメーターに割り当てられた型が含まれます。If the current method is a closed constructed method (that is, the ContainsGenericParameters property returns false), the array returned by the GetGenericArguments method contains the types that have been assigned to the generic type parameters of the generic method definition.

  • 現在のメソッドがジェネリックメソッドの定義である場合、配列には型パラメーターが含まれます。If the current method is a generic method definition, the array contains the type parameters.

  • 現在のメソッドがオープン構築メソッド (つまり、 ContainsGenericParameters プロパティがを返す) である場合、特定の型 true が一部の型パラメーターに割り当てられており、外側のジェネリック型の型パラメーターが他の型パラメーターに割り当てられている場合、配列には型と型の両方のパラメーターが含まれます。If the current method is an open constructed method (that is, the ContainsGenericParameters property returns true) in which specific types have been assigned to some type parameters and type parameters of enclosing generic types have been assigned to other type parameters, the array contains both types and type parameters. プロパティを使用して、これらの値 IsGenericParameter を区別します。Use the IsGenericParameter property to tell them apart. このシナリオのデモについては、プロパティのコード例を参照してください ContainsGenericParametersFor a demonstration of this scenario, see the code example for the ContainsGenericParameters property.

ジェネリックメソッドに固有の用語の不変条件の一覧については、「」プロパティを参照してください IsGenericMethodFor a list of the invariant conditions for terms specific to generic methods, see the IsGenericMethod property. 汎用リフレクションで使用されるその他の用語の不変条件の一覧については、プロパティを参照してください Type.IsGenericTypeFor a list of the invariant conditions for other terms used in generic reflection, see the Type.IsGenericType property.

適用対象

こちらもご覧ください