MethodBuilder.MakeGenericMethod(Type[]) Método
Definição
Importante
Algumas informações dizem respeito a um produto pré-lançado que pode ser substancialmente modificado antes de ser lançado. A Microsoft não faz garantias, de forma expressa ou implícita, em relação à informação aqui apresentada.
Devolve um método genérico construído a partir da definição atual do método genérico usando os argumentos do tipo genérico especificados.
public:
override System::Reflection::MethodInfo ^ MakeGenericMethod(... cli::array <Type ^> ^ typeArguments);
public override System.Reflection.MethodInfo MakeGenericMethod(params Type[] typeArguments);
override this.MakeGenericMethod : Type[] -> System.Reflection.MethodInfo
Public Overrides Function MakeGenericMethod (ParamArray typeArguments As Type()) As MethodInfo
Parâmetros
- typeArguments
- Type[]
Um array de Type objetos que representam os argumentos de tipo para o método genérico.
Devoluções
A MethodInfo representa o método genérico construído a partir da definição atual do método genérico usando os argumentos do tipo genérico especificados.
Exemplos
O exemplo de código seguinte cria um método construído a partir de uma definição genérica incompleta de método num tipo incompleto.
O exemplo cria um conjunto transitório e um módulo com um único tipo, adiciona um método M, e torna o método genérico ao adicionar um parâmetro de tipo T usando o DefineGenericParameters método. O parâmetro de tipo é usado como o tipo do parâmetro do método, e também como o seu tipo de retorno. A definição genérica do método não recebe um corpo, e o tipo de anexo não é concluído. O método MakeGenericMethod é então usado para tornar o método construído M<String> (M(Of String) em Visual Basic). O código de exemplo não tem saída, porque a subclasse de MethodInfo devolvida pelo MakeGenericMethod método não permite reflexão sobre os seus parâmetros.
Note
Para outro exemplo de código que use MakeGenericMethod, veja DefineGenericParameters. MakeGenericMethod é também amplamente utilizado ao emitir código que utiliza tipos genéricos. Veja como: Definir um método genérico com emissão por reflexão.
using System;
using System.Reflection;
using System.Reflection.Emit;
class Example
{
public static void Main()
{
// Define a transient dynamic assembly (only to run, not
// to save) with one module and a type "Test".
//
AssemblyName aName = new AssemblyName("MyDynamic");
AssemblyBuilder ab =
AppDomain.CurrentDomain.DefineDynamicAssembly(
aName,
AssemblyBuilderAccess.Run);
ModuleBuilder mb = ab.DefineDynamicModule(aName.Name);
TypeBuilder tb = mb.DefineType("Test");
// Add a public static method "M" to Test, and make it a
// generic method with one type parameter named "T").
//
MethodBuilder meb = tb.DefineMethod("M",
MethodAttributes.Public | MethodAttributes.Static);
GenericTypeParameterBuilder[] typeParams =
meb.DefineGenericParameters(new string[] { "T" });
// Give the method one parameter, of type T, and a
// return type of T.
meb.SetParameters(typeParams);
meb.SetReturnType(typeParams[0]);
// Create a MethodInfo for M<string>, which can be used in
// emitted code. This is possible even though the method
// does not yet have a body, and the enclosing type is not
// created.
MethodInfo mi = meb.MakeGenericMethod(typeof(string));
// Note that this is actually a subclass of MethodInfo,
// which has rather limited capabilities -- for
// example, you cannot reflect on its parameters.
}
}
Imports System.Reflection
Imports System.Reflection.Emit
Class Example
Public Shared Sub Main()
' Define a transient dynamic assembly (only to run, not
' to save) with one module and a type "Test".
'
Dim aName As AssemblyName = New AssemblyName("MyDynamic")
Dim ab As AssemblyBuilder = _
AppDomain.CurrentDomain.DefineDynamicAssembly( _
aName, _
AssemblyBuilderAccess.Run)
Dim mb As ModuleBuilder = ab.DefineDynamicModule(aName.Name)
Dim tb As TypeBuilder = mb.DefineType("Test")
' Add a Public Shared method "M" to Test, and make it a
' generic method with one type parameter named "T").
'
Dim meb As MethodBuilder = tb.DefineMethod("M", _
MethodAttributes.Public Or MethodAttributes.Static)
Dim typeParams() As GenericTypeParameterBuilder = _
meb.DefineGenericParameters(New String() { "T" })
' Give the method one parameter, of type T, and a
' return type of T.
meb.SetParameters(typeParams)
meb.SetReturnType(typeParams(0))
' Create a MethodInfo for M(Of String), which can be used
' in emitted code. This is possible even though the method
' does not yet have a body, and the enclosing type is not
' created.
Dim mi As MethodInfo = _
meb.MakeGenericMethod(GetType(String))
' Note that this is actually a subclass of MethodInfo,
' which has rather limited capabilities -- for
' example, you cannot reflect on its parameters.
End Sub
End Class
Observações
Quando está a emitir código dinâmico, pode ser necessário emitir uma chamada para um método construído a partir da definição genérica do método representada por um MethodBuilder, antes de o tipo anexo ser concluído. Pode usar o MakeGenericMethod método para criar um MethodInfo para tal método construído, e usar o MethodInfo na chamada emitida.