在本节我们需要看看这个Mono.Cecil,先来一个简单的认识。
我来在我们的方法执行前后加入我们的输出信息:
原来代码:
class Program{
static voID Main( string [] args)
{
Console.Writeline( " 破浪Blog:http://www.cnblogs.com/whitewolf/ " );
}
}
任务:
1我将在方法执行前后添加一个Console.Writeline("Method start…");
2方法最后添加Console.Writeline("Method finish…“);
具体Mono.Cecil Code:
using System;using System.Collections.Generic;
using System.linq;
using System.Text;
using Mono.Cecil;
using Mono.Cecil.Cil;
namespace BlogSample
{
class Program
{
static voID Main( string [] args)
{
AssemblyDeFinition assembiy = AssemblyFactory.GetAssembly(args[ 0 ]);
foreach (Mono.Cecil.TypeDeFinition item in assembiy.MainModule.Types)
{
foreach (MethodDeFinition method in item.Methods)
{
if (method.name.Equals( " Main " ))
{
var ins = method.Body.Instructions[ 0 ];
var worker = method.Body.CilWorker;
worker.InsertBefore(ins, worker.Create(OpCodes.Ldstr, " Method start… " ));
worker.InsertBefore(ins, worker.Create(OpCodes.Call,
assembiy.MainModule.import( typeof (Console).getmethod( " Writeline " , new Type[] { typeof ( string ) }))));
ins = method.Body.Instructions[method.Body.Instructions.Count - 1 ];
worker.InsertBefore(ins, " Method finish… " ));
worker.InsertBefore(ins, new Type[] { typeof ( string ) }))));
break ;
}
}
}
AssemblyFactory.SaveAssembly(assembiy, " IL_ " + args[ 0 ]);
Console.Read();
}
}
}
DOS运行结果:
我们在来看看反编译后的MSIL
C#:
在这最后我们可以想一下,如果我们利用Mono.Cecil可以干些什么事情,能做的当然很多,我首先想尝试的了与上一节浅谈VS编译自定义编译任务—MSBuild Task(csproject)结合postsharp一样的静态注入AOP框架。还能做什么的就要靠大家发挥大家聪明的才智。
总结以上是内存溢出为你收集整理的编译时MSIL注入--实践Mono Cecil(1)全部内容,希望文章能够帮你解决编译时MSIL注入--实践Mono Cecil(1)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)