最近在看Enpert .NET 2.0 IL Assembler这本书,可能会花去我很多时间,不过只是看了第一张就被它折服了,原作者简直是庖丁解牛,层层深入。翻译又是那么牛B,此书建议有想深入了解NET的朋友一看。
下面用vs自带的IL汇编和反汇编器做个小demo,算是对工具的简单使用吧。
vs建个控制台程序,fm 4.0的。来个hello world。然后编译下生成下,去它的bin目录找到exe
打开ILDASM工具。它在这里:C:\Program Files (x86)\Microsoft SDKs\Windows\v8.1A\bin\NETFX 4.5.1 Tools\ildasm.exe
打开它,然后将刚刚生成的exe拖进去,然后【文件-->转存】为IL文件。这里关于ildasm工具的各种图标意义可以看它的帮助文档(chm),这里贴上
可以用文本编辑器打开这个il文件,结构如下:
// Microsoft (R) .NET Framework IL Disassembler. Version 4.0.30319.33440
// Metadata version: v4.0.30319
.assembly extern mscorlib
{
.publickeytoken = (B7 7A 5C 56 19 34 E0 89 ) // .z\V.4..
.ver 4:0:0:0
}
.assembly helloworld
{
.custom instance void [mscorlib]System.Runtime.Versioning.TargetFrameworkAttribute::.ctor(string) = ( 01 00 1A 2E 4E 45 54 46 72 61 6D 65 77 6F 72 6B // ....NETFramework
2C 56 65 72 73 69 6F 6E 3D 76 34 2E 30 01 00 54 // ,Version=v4.0..T
0E 14 46 72 61 6D 65 77 6F 72