我的情景: 我想在日志文件中写入发生异常的部分代码(例如,之前的5行和发生异常的5行之后 - 或者至少是该方法的所有代码)。
我的想法是用C#代码反编译pdb文件,并从反编译文件中找到一个在catch块中异常的方法。
Pbd文件存在,我的应用程序构建为调试版本。我知道有些工具允许通过其GUI(例如Reflector)进行反编译,但我希望从我的代码中获得该功能。
怎么做?
答案 0 :(得分:4)
PDB包含MSIL和源文件名/行号之间的映射。当您可以返回并查看原始源文件时,这非常有用,因为反编译通常不会保留行号(尽管它也可以使用PDB文件)。它当然不能完全按照书面形式恢复原始代码,尽管使用符号名称(也存储在PDB中)它通常会很接近。
答案 1 :(得分:2)
查看ILSpy的源代码。它是Reflector的开源替代品。
特别是它使用了库Mono.Cecil
和Mono.Cecil.Pdb
。我怀疑后者可以帮助你做你想做的事。
相关代码部分使用MIT许可证,这是许可证。
答案 2 :(得分:0)
使用反射来获取执行方法的源代码:System.Reflection.MethodBase.GetCurrentMethod().GetMethodBody();
您可以使用MethodBase成员获得各种信息:http://msdn.microsoft.com/en-us/library/system.reflection.methodbase_methods.aspx
另请参阅此处,了解在异常处理时获取MethodBase信息的一些好例子:http://msdn.microsoft.com/en-us/library/system.reflection.methodbase.getmethodbody.aspx#Y563