反射-Emit
一、Emit
Emit,可以称为发出或者产出。在Framework中,与Emit相关的类基本都存在与System.Reflection,Emit命名空间下。可见Emit是作为反射的一个元素存在,反射可以查看程序集的元数据,获取程序集包含哪些类型,类型包含哪些方法等,但是反射只能“看”,Emit可以在运行时动态生成代码(IL),.net就可以执行。反射主要用到对象已经存在的情况下,而反射发出主要用到对象并不存在等情况下(而利用代码动态的构建对象)。
二、动态生成代码(IL代码)
1.构建程序集
var as = new AssemblyName("TEST");
//AssemblyBuilderAccess.RunAndSave 表示动态程序集会被保存至磁盘并能立即执行。
var asmBuilder=AppDomain.CurrentDomain.DefineDynamicAssembly(asmName,AssemblyBuilderAccess.RunAndSave);
AssemblyBuilderAccess,ReflectionOnly;
2.创建模块
var mdlBldr = asmBuilder.DefineDynamicModult("Main","Main.dll");
3.定义类
var typeBldr=mdlBldr.DefineType("Hello",TypeAttributes.Public);
4.定义类成员
var methodBldr = typeBldr.DefineMethod(
"SayHello",
MethodAttributes.Public,
null,//返回类型
null//参数类型
)
方法的原型即为 SayHello
Console.WriteLine("Hello World");
var i = methodBldr.GetILGenerator();//获取IL生成器
il.Emit(OpCodes.Ldstr,"Hello, World");
il.Emit(OpCodes.Call,typeof(Console).GetMethod("WriteLine",new Type[]{typeof(string)}));
il.Emit(OpCodes.Ret);
OpCodes枚举定义了所有可能的操作,这里用到了:
ldStr:加载一个字符串到evaluation stack。
Call:调用方法。
Ret:返回,当evaluation stack有值时会返回栈顶值。
完成上面的步骤,一个类型好像就已经完成了。事实上却还没有,最后我们还必须显示的调用CreateType来完成类型的创建。
这样一个完整的类就算完成了。但为了能用reflector查看我们创建的动态程序集,我们选择将这个程序集保存下来。
如前面定义模块时所说,这里文件名字必须和模块保存到的文件一致,否则我们前面定义的模块和这个模块的一切就无家可归了。接下来,(如果在定义模块时未指定动态创建的程序要保存到哪个目录)我们就可以到 Debug目录下看看生成的Main.dll了,用Reflector打开可以看到:
三、不包含main的控制台程序
一直以来,应用程序(控制台,winform)都是从Main函数启动的,如果没有Main还能启动吗?答案是可以,下面就用emit来做这样一个控制台程序,完整代码如下:
var asmBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(
asmName,
AssemblyBuilderAccess.RunAndSave);
var mdlBldr = asmBuilder.DefineDynamicModule("Main", "Main.exe");
var typeBldr = mdlBldr.DefineType("Hello", TypeAttributes.Public);
var methodBldr = typeBldr.DefineMethod(
"SayHello",
MethodAttributes.Public | MethodAttributes.Static,
null,//return type
null//parameter type
);
var il = methodBldr.GetILGenerator();//获取il生成器
il.Emit(OpCodes.Ldstr,"Hello, World");
il.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[]{typeof(string)}));
il.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
il.Emit(OpCodes.Pop);//读入的值会被推送至evaluation stack,而本方法是没有返回值的,因此,需要将栈上的值抛弃
il.Emit(OpCodes.Ret);
var t = typeBldr.CreateType();
asmBuilder.SetEntryPoint(t.GetMethod("SayHello"));
asmBuilder.Save("Main.exe");
运行生成的Main.exe效果如下:
例
#region
//得到当前的应用程序域
AppDomain app = AppDomain.CurrentDomain;
//初始化AssemblyName的一个实例
AssemblyName an = new AssemblyName("EmitLearn");
//设置程序集的名称
// an.Name = "EmitLearn";
//动态的在当前应用程序域创建一个应用程序集
AssemblyBuilder a = app.DefineDynamicAssembly(an, System.Reflection.Emit.AssemblyBuilderAccess.RunAndSave);
//动态在程序集内创建一个模块
ModuleBuilder mb = a.DefineDynamicModule("EmitLearn", "HelloEmit.dll");
//动态的在模块内创建一个类
TypeBuilder tb = mb.DefineType("HelloEmit", TypeAttributes.Public | TypeAttributes.Class);
//动态的为类里创建一个方法
MethodBuilder mdb = tb.DefineMethod("SayHelloEmit", MethodAttributes.Public, null, new Type[] { typeof(string) }); //得到该方法的iLGenerator
ILGenerator il = mdb.GetILGenerator();
il.Emit(OpCodes.Ldstr, "你好");
//加载传入方法的参数的堆栈
il.Emit(OpCodes.Ldarg_0); il.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
il.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//没有返回值所有加Pop
il.Emit(OpCodes.Pop);
il.Emit(OpCodes.Ret);
//创建类的Type对象
Type tp = tb.CreateType();
a.Save("HelloEmit.dll");
//实例化一个类
object ob = Activator.CreateInstance(tp);
//得到类中的方法,通过Invoke来触发方法的调用
MethodInfo mdth = tp.GetMethod("SayHelloEmit");
//mdth.Invoke(ob, null);
mdth.Invoke(ob, new object[] { "摩天大楼" });
#endregion
了解完Emit的基本概念后就应该实际动手操作一下了,就像C#代码一样Emit代码也不是都需要理解的,复杂的逻辑当然需要理解,但是像string str=”abc”;这样的就不用深究了吧,知道这是干嘛的就行了。
没有了解过Emit和IL的朋友请先看看下面两篇文章:
Emit基本概念介绍:http://blog.csdn.net/xiaouncle/article/details/52621815
轻松读懂IL:http://blog.csdn.net/xiaouncle/article/details/52770462
【无返回值】无参方法SayHello()
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public, null, null);
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//没有返回值所有加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点2】
methodInfo.Invoke(obj, null);
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
.Net Reflector转换后代码:
public class Person
{
// Methods
public void SayHello()
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
【无返回值】静态无参方法SayHello()
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public | MethodAttributes.Static, null, null);
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//没有返回值所有加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点2】
methodInfo.Invoke(obj, null);
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
.Net Reflector转换后代码:
public class Person
{
// Methods
public static void SayHello()
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
【无返回值】含参方法SayHello(string name)
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public, null, new Type[] { typeof(string) });
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "你好:{0}");
//【不同点2】
ilOfSayHello.Emit(OpCodes.Ldarg_1);
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string), typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//没有返回值所有加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点3】
methodInfo.Invoke(obj, new object[] { "蝈蝈" });
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
.Net Reflector转换后代码:
public class Person
{
// Methods
public void SayHello(string text1)
{
Console.WriteLine("你好:{0}", text1);
Console.ReadLine();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
【无返回值】静态含参方法SayHello(string name)
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public | MethodAttributes.Static, null, new Type[] { typeof(string) });
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "你好:{0}");
//【不同点2】
ilOfSayHello.Emit(OpCodes.Ldarg_0);
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string), typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//没有返回值所有加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点3】
methodInfo.Invoke(obj, new object[] { "蝈蝈" });
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
.Net Reflector转换后代码:
public class Person
{
// Methods
public static void SayHello(string text1)
{
Console.WriteLine("你好:{0}", text1);
Console.ReadLine();
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
【有返回值】无参方法SayHello()
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public, typeof(string), null);
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//为什么加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
//返回值部分
LocalBuilder local = ilOfSayHello.DeclareLocal(typeof(string));
ilOfSayHello.Emit(OpCodes.Ldstr, "返回值");
ilOfSayHello.Emit(OpCodes.Stloc_0, local);
ilOfSayHello.Emit(OpCodes.Ldloc_0, local);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点2】
object result = methodInfo.Invoke(obj, null);
Console.WriteLine("result=" + result.ToString());
Console.ReadKey();
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
.Net Reflector转换后代码:
public class Person
{
// Methods
public string SayHello()
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
return "返回值";
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
【有返回值】静态无参方法SayHello()
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public | MethodAttributes.Static, typeof(string), null);
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//为什么加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
//返回值部分
LocalBuilder local = ilOfSayHello.DeclareLocal(typeof(string));
ilOfSayHello.Emit(OpCodes.Ldstr, "返回值");
ilOfSayHello.Emit(OpCodes.Stloc_0, local);
ilOfSayHello.Emit(OpCodes.Ldloc_0, local);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点2】
object result = methodInfo.Invoke(obj, null);
Console.WriteLine("result=" + result.ToString());
Console.ReadKey();
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
.Net Reflector转换后代码:
public class Person
{
// Methods
public static string SayHello()
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
return "返回值";
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
【有返回值】含参方法SayHello(string name)
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public, typeof(string), new Type[] { typeof(string) });
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//为什么加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
//返回值部分
LocalBuilder local = ilOfSayHello.DeclareLocal(typeof(string));
ilOfSayHello.Emit(OpCodes.Ldstr, "99999{0}");
//【不同点2】
ilOfSayHello.Emit(OpCodes.Ldarg_1);
ilOfSayHello.Emit(OpCodes.Call, typeof(string).GetMethod("Format", new Type[] { typeof(string), typeof(string) }));
ilOfSayHello.Emit(OpCodes.Stloc_0, local);
ilOfSayHello.Emit(OpCodes.Ldloc_0, local);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点3】
object result = methodInfo.Invoke(obj, new object[] { "蝈蝈" });
Console.WriteLine("result=" + result.ToString());
Console.ReadKey();
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
.Net Reflector转换后代码:
public class Person
{
// Methods
public string SayHello(string text1)
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
return string.Format("99999{0}", text1);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
【有返回值】静态含参方法SayHello(string name)
Emit代码:
static void Main(string[] args)
{
AssemblyName assemblyName = new AssemblyName("assemblyName");
AssemblyBuilder assemblyBuilder = AppDomain.CurrentDomain.DefineDynamicAssembly(assemblyName, AssemblyBuilderAccess.RunAndSave);
ModuleBuilder moduleBuilder = assemblyBuilder.DefineDynamicModule("PersonModule", "Person.dll");
TypeBuilder typeBuilder = moduleBuilder.DefineType("Person", TypeAttributes.Public);
//*【不同点1】
MethodBuilder sayHelloMethod = typeBuilder.DefineMethod("SayHello", MethodAttributes.Public | MethodAttributes.Static, typeof(string), new Type[] { typeof(string) });
ILGenerator ilOfSayHello = sayHelloMethod.GetILGenerator();
ilOfSayHello.Emit(OpCodes.Ldstr, "蝈蝈");
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }));
ilOfSayHello.Emit(OpCodes.Call, typeof(Console).GetMethod("ReadLine"));
//为什么加OpCodes.Pop
ilOfSayHello.Emit(OpCodes.Pop);
//返回值部分
LocalBuilder local = ilOfSayHello.DeclareLocal(typeof(string));
ilOfSayHello.Emit(OpCodes.Ldstr, "99999{0}");
//【不同点2】
ilOfSayHello.Emit(OpCodes.Ldarg_0);
ilOfSayHello.Emit(OpCodes.Call, typeof(string).GetMethod("Format", new Type[] { typeof(string), typeof(string) }));
ilOfSayHello.Emit(OpCodes.Stloc_0, local);
ilOfSayHello.Emit(OpCodes.Ldloc_0, local);
ilOfSayHello.Emit(OpCodes.Ret);
Type personType = typeBuilder.CreateType();
assemblyBuilder.Save("Person.dll");
object obj = Activator.CreateInstance(personType);
MethodInfo methodInfo = personType.GetMethod("SayHello");
//【不同点3】
object result = methodInfo.Invoke(obj, new object[] { "蝈蝈" });
Console.WriteLine("result=" + result.ToString());
Console.ReadKey();
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
.Net Reflector转换后代码:
public class Person
{
// Methods
public static string SayHello(string text1)
{
Console.WriteLine("蝈蝈");
Console.ReadLine();
return string.Format("99999{0}", text1);
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
实例代码免费下载地址:http://download.csdn.net/detail/xiaouncle/9649675
.Net Reflector Version 9.0.1.374 带注册机免费下载地址: http://download.csdn.net/detail/xiaouncle/9649783
原:https://blog.csdn.net/xiaouncle/article/details/52776007
反射-Emit的更多相关文章
- IoC原理-使用反射/Emit来实现一个最简单的IoC容器
从Unity到Spring.Net,到Ninject,几年来陆陆续续用过几个IoC框架.虽然会用,但也没有一直仔细的研究过IoC实现的过程.最近花了点时间,下了Ninject的源码,研究了一番,颇有收 ...
- 含有ref out 参数 的方法反射 Emit 与 普通
反射中很多朋友应该屡屡被带有ref out参数的方法折腾 当使用正常反射一个方法时候: 代码如下调用一个后期绑定方法MakeByRefType 就行了 MemberInfo test = typeof ...
- .NET(C#):分析IL中的if-else,while和for语句并用Emit实现
这是一篇关于IL和反射Emit的文章(所以不喜欢IL或者Emit的就没必要往下看了),要求读者对IL和Emit工作原理较了解.所有分析IL均在Visual Studio 2010 SP1下编译生成.( ...
- Deep Clone 常用方式总结
Deep Clone Example 总结 Deep Clone 一般有如下几种实现方式: 纯手工每个类实现赋值 (ps: 不做介绍,一般都不想这么玩) 序列化和反序列化 纯反射 emit 或 Exp ...
- [翻译] .NET Standard 2.1 公布
[翻译] .NET Standard 2.1 公布 原文: Announcing .NET Standard 2.1 校对: Cloud 自从大约一年前发布 .NET Standard 2.0以来,我 ...
- C#中反射的使用(How to use reflect in CSharp)(3)Emit的使用
Emit意在动态构建一个可以执行(当然也就可以反射)或者只可以反射的动态库. 个人认为在不得不使用反射的情况下,使用Emit会使得效率提升空间很大.亦或者动态插件模式的软件设计中会用到. 依然2%的废 ...
- C#利用Emit反射实现AOP,以及平台化框架封装思路
C#利用Emit反射实现AOP,以及平台化框架封装思路 这是前两天扒的一段动态代理AOP代码,用的Emit反射生成子类来实现代理模式,在这里做个小笔记,然后讨论一下AOP框架的实现思路. 首先是主函数 ...
- 再看ExpressionTree,Emit,反射创建对象性能对比
[前言] 前几日心血来潮想研究着做一个Spring框架,自然地就涉及到了Ioc容器对象创建的问题,研究怎么高性能地创建一个对象.第一联想到了Emit,兴致冲冲写了个Emit创建对象的工厂.在做性能测试 ...
- 什么是Emit,什么是反射,二者区别到底是什么?(转)
Emit的准确定义,我们看看微软给出的答案 System.Reflection.Emit 命名空间包含{ 允许编译器或工具发出元数据和发出 Microsoft 中间语言 (MSIL) ,并可选择在磁盘 ...
随机推荐
- js-DOM事件
var EventUtil = { addHandler:function(elm,type,handler){//添加事件 if(elm.addEventListener){ elm.addEven ...
- Oracle12C_____处理数据库01033连接错误问题.sql
Microsoft Windows [版本 6.1.7601] 版权所有 (c) 2009 Microsoft Corporation.保留所有权利. C:\Users\Administrator&g ...
- Confluence 6 附件是如何被索引的
当一个文件被上传到 Confluence 后,Confluence 将会尝试对文件进行解压,然后对文件中的内容进行索引.这样系统就能够允许用户对文件中的内容进行搜索,而不仅仅是搜索文件名.这个过程对系 ...
- vue项目中 axios 和Vue-axios的关系
文章收集于:https://segmentfault.com/q/1010000010812113 在vue项目中,会经常看到如下代码: 今天看到有些项目是这样写的,就有点看不懂了. ----解 ...
- Java 把一个文本文档的内容复制到另一个文本文档
src.txt放在工程目录下,dest.txt可创建,也可不创建.一旦运行程序,如果dest.txt不存在,将自行创建这个文本文档,再将src.txt中的内容复制到dest.txt import ja ...
- SpringBoot系列七:SpringBoot 整合 MyBatis(配置 druid 数据源、配置 MyBatis、事务控制、druid 监控)
1.概念:SpringBoot 整合 MyBatis 2.背景 SpringBoot 得到最终效果是一个简化到极致的 WEB 开发,但是只要牵扯到 WEB 开发,就绝对不可能缺少数据层操作,所有的开发 ...
- Jmeter卡住解决方案
windows环境下,修改jmeter.bat: set HEAP=-Xms256m -Xmx256m set NEW=-XX:NewSize=128m -XX:MaxNewSize=128m 改为: ...
- js两种写法执行速度比较
记录 function test1(){ this.say = function(){} } function test2(){ this.say = function(){} return this ...
- Eclipes导入工程
1.在eclipes中导入其他的一些工程后往往会出错,修改意见是 在project.properties该文件下修改 这个target是你的sdk中已经下载好的 查看: 右键目标工程,选择proper ...
- HTTP 599: SSL certificate problem: unable to get local issuer certificate错误
自己在用 PySpider 框架爬虫运行代码后时出现 HTTP 599: SSL certificate problem: unable to get local issuer certificate ...