繁体   English   中英

使用Reflection.Emit创建方法,然后调用它

[英]Creating a method with Reflection.Emit, and then invoking it

这听起来很明显,但我遇到了很多困难。 基本上,我正在做的是使用Reflection.Emit生成一个方法然后我想调用它。 到目前为止,我有方法构建等,但是在构建之后我无法获得对该方法的引用,因为“在创建类型之前不支持被调用的成员”。

这是我基本上做的:

AssemblyBuilder assembly;
ModuleBuilder module;
TypeBuilder containerTypeBuilder;
Type containerType;
var name = new AssemblyName();
name.Name = "DynamicWrapper";
var domain = Thread.GetDomain();
assembly = domain.DefineDynamicAssembly(name, AssemblyBuilderAccess.RunAndSave);
module = assembly.DefineDynamicModule(assembly.GetName().Name, false);
containerTypeBuilder = module.DefineType("__DynamicWrapperType",
                              TypeAttributes.Public | TypeAttributes.Class |
                              TypeAttributes.AutoClass |
                              TypeAttributes.AnsiClass | TypeAttributes.BeforeFieldInit |
                              TypeAttributes.AutoLayout, typeof(object));
//build method
var mb = containerTypeBuilder.DefineMethod("generatedmethod" + (unique++),
                              MethodAttributes.Public | MethodAttributes.Static, typeof (int),
                              new Type[] {});
//build method body and all that
.....
var type=module.GetType("__DynamicWrapperType");
var info=type.GetMethod(mb.Name, BindingFlags.Static | BindingFlags.Public); //error here

我如何采用我新构建的方法并加载它以便我可以调用它?

此外,我已经尝试过mb.Invoke ,但这会产生“动态模块中不支持调用的成员”。

如果您正在创建单个方法,那么DynamicMethod是一个更好的选择(特别是因为您的方法是静态的) - 您只需使用CreateDelegate (指定委托类型), 强制转换为该委托,然后调用。 它也减少了开销,并且具有收藏价值。

但是如果你被迫使用MethodBuilder :你必须在TypeBuilder上使用CreateType ,然后对现在真实的类型使用反射(从CreateType返回)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM