MethodInfo.GetGenericMethodDefinition Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Retorna um objeto MethodInfo que representa uma definição de método genérico da qual o método atual pode ser criado.
public:
virtual System::Reflection::MethodInfo ^ GetGenericMethodDefinition();
public virtual System.Reflection.MethodInfo GetGenericMethodDefinition ();
[System.Runtime.InteropServices.ComVisible(true)]
public virtual System.Reflection.MethodInfo GetGenericMethodDefinition ();
abstract member GetGenericMethodDefinition : unit -> System.Reflection.MethodInfo
override this.GetGenericMethodDefinition : unit -> System.Reflection.MethodInfo
[<System.Runtime.InteropServices.ComVisible(true)>]
abstract member GetGenericMethodDefinition : unit -> System.Reflection.MethodInfo
override this.GetGenericMethodDefinition : unit -> System.Reflection.MethodInfo
Public Overridable Function GetGenericMethodDefinition () As MethodInfo
Retornos
Um objeto MethodInfo que representa uma definição de método genérico da qual o método atual pode ser criado.
- Atributos
Exceções
O método atual não é um método genérico. Ou seja, IsGenericMethod retorna false
.
Não há suporte para o método.
Exemplos
O exemplo de código a seguir mostra uma classe com um método genérico e o código necessário para obter um MethodInfo para o método, associar o método a argumentos de tipo e obter a definição de tipo genérico original de volta do método associado.
Este exemplo faz parte de um exemplo maior fornecido para o MakeGenericMethod método .
// Define a class with a generic method.
ref class Example
{
public:
generic<typename T> static void Generic(T toDisplay)
{
Console::WriteLine("\r\nHere it is: {0}", toDisplay);
}
};
// Define a class with a generic method.
public class Example
{
public static void Generic<T>(T toDisplay)
{
Console.WriteLine("\r\nHere it is: {0}", toDisplay);
}
}
' Define a class with a generic method.
Public Class Example
Public Shared Sub Generic(Of T)(ByVal toDisplay As T)
Console.WriteLine(vbCrLf & "Here it is: {0}", toDisplay)
End Sub
End Class
// Create a Type object representing class Example, and
// get a MethodInfo representing the generic method.
//
Type^ ex = Example::typeid;
MethodInfo^ mi = ex->GetMethod("Generic");
DisplayGenericMethodInfo(mi);
// Assign the int type to the type parameter of the Example
// method.
//
MethodInfo^ miConstructed = mi->MakeGenericMethod(int::typeid);
DisplayGenericMethodInfo(miConstructed);
// Create a Type object representing class Example, and
// get a MethodInfo representing the generic method.
//
Type ex = typeof(Example);
MethodInfo mi = ex.GetMethod("Generic");
DisplayGenericMethodInfo(mi);
// Assign the int type to the type parameter of the Example
// method.
//
MethodInfo miConstructed = mi.MakeGenericMethod(typeof(int));
DisplayGenericMethodInfo(miConstructed);
' Create a Type object representing class Example, and
' get a MethodInfo representing the generic method.
'
Dim ex As Type = GetType(Example)
Dim mi As MethodInfo = ex.GetMethod("Generic")
DisplayGenericMethodInfo(mi)
' Assign the Integer type to the type parameter of the Example
' method.
'
Dim arguments() As Type = { GetType(Integer) }
Dim miConstructed As MethodInfo = mi.MakeGenericMethod(arguments)
DisplayGenericMethodInfo(miConstructed)
// Get the generic type definition from the closed method,
// and show it's the same as the original definition.
//
MethodInfo^ miDef = miConstructed->GetGenericMethodDefinition();
Console::WriteLine("\r\nThe definition is the same: {0}",
miDef == mi);
// Get the generic type definition from the closed method,
// and show it's the same as the original definition.
//
MethodInfo miDef = miConstructed.GetGenericMethodDefinition();
Console.WriteLine("\r\nThe definition is the same: {0}",
miDef == mi);
' Get the generic type definition from the constructed method,
' and show that it's the same as the original definition.
'
Dim miDef As MethodInfo = miConstructed.GetGenericMethodDefinition()
Console.WriteLine(vbCrLf & "The definition is the same: {0}", _
miDef Is mi)
Comentários
Uma definição de método genérico é um modelo do qual os métodos podem ser construídos. Por exemplo, na definição T M<T>(T t)
de método genérico (expressa na sintaxe C#; Function M(Of T)(ByVal tVal As T) As T
no Visual Basic), você pode construir e invocar o método int M<int>(int t)
(Function M(Of Integer)(ByVal tVal As Integer) As Integer
no Visual Basic). Dado um MethodInfo objeto que representa esse método construído, o GetGenericMethodDefinition método retorna a definição de método genérico.
Se dois métodos construídos forem criados a partir da mesma definição de método genérico, o GetGenericMethodDefinition método retornará o mesmo MethodInfo objeto para ambos os métodos.
Se você chamar GetGenericMethodDefinition em um MethodInfo que já representa uma definição de método genérico, ele retornará o atual MethodInfo.
Se uma definição de método genérico incluir parâmetros genéricos do tipo de declaração, haverá uma definição de método genérico específica para cada tipo construído. Por exemplo, considere o seguinte código C#, Visual Basic e C++:
class B<U,V> {}
class C<T> { public B<T,S> M<S>() {...}}
Class B(Of U, V)
End Class
Class C(Of T)
Public Function M(Of S)() As B(Of T, S)
...
End Function
End Class
generic <typename U, typename V> ref class B {};
generic <typename T> ref class C
{
public:
generic <typename S> B<T,S>^ M() {...};
};
No tipo C<int>
construído (C(Of Integer)
no Visual Basic), o método M
genérico retorna B<int, S>
. No tipo C<T>
aberto , M
retorna B<T, S>
. Em ambos os casos, a IsGenericMethodDefinition propriedade retorna true
para o MethodInfo que representa M
, portanto MakeGenericMethod , pode ser chamada em ambos os MethodInfo objetos. No caso do tipo construído, o resultado da chamada MakeGenericMethod é um MethodInfo que pode ser invocado. No caso do tipo aberto, o MethodInfo retornado por MakeGenericMethod não pode ser invocado.
Para obter uma lista das condições invariáveis para termos específicos a métodos genéricos, consulte a IsGenericMethod propriedade . Para obter uma lista das condições invariáveis para outros termos usados na reflexão genérica, consulte a IsGenericType propriedade .