MethodInfo.GetGenericArguments MethodInfo.GetGenericArguments MethodInfo.GetGenericArguments MethodInfo.GetGenericArguments Method

Определение

Возвращает массив объектов 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();
[System.Runtime.InteropServices.ComVisible(true)]
public override Type[] GetGenericArguments ();
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.

Этот пример является частью большого примера, приведенного для MakeGenericMethod метода.This 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. Демонстрацию этого сценария см. в примере кода для ContainsGenericParameters свойства.For a demonstration of this scenario, see the code example for the ContainsGenericParameters property.

Список инвариантных условий для терминов, характерных для универсальных методов, см. IsGenericMethod в описании свойства.For a list of the invariant conditions for terms specific to generic methods, see the IsGenericMethod property. Список инвариантных условий для других терминов, используемых в универсальном отражении, см. Type.IsGenericType в описании свойства.For a list of the invariant conditions for other terms used in generic reflection, see the Type.IsGenericType property.

Применяется к

Дополнительно