Практическое руководство. Просмотр содержимого сборки

Вы можете использовать Ildasm.exe (IL Disassembler) для просмотра сведений о общем промежуточном языке (CIL) в файле. Если анализируемый файл является сборкой, то эти данные могут включать в себя атрибуты сборки, а также ссылки на другие модули и сборки. Эти данные полезны для определения того, является ли файл сборкой или частью сборки и содержит ли он ссылки на другие модули и сборки.

Чтобы отобразить содержимое сборки с помощью Ildasm.exe, введите имя> сборки ildasm <в командной строке. Например, следующая команда дизассемблирует сборку Hello.exe.

ildasm Hello.exe

Чтобы просмотреть сведения о манифесте сборки, дважды щелкните значок манифеста в окне disassembler IL.

Пример

Следующий пример начинается с простой программы "Hello World". После компиляции программы используйте Ildasm.exe, чтобы декомпилировать сборку Hello.exe и просмотреть манифест сборки.

using namespace System;

class MainApp
{
public:
    static void Main()
    {
        Console::WriteLine("Hello World using C++/CLI!");
    }
};

int main()
{
    MainApp::Main();
}
using System;

class MainApp
{
    public static void Main()
    {
        Console.WriteLine("Hello World using C#!");
    }
}
Class MainApp
    Public Shared Sub Main()
        Console.WriteLine("Hello World using Visual Basic!")
    End Sub
End Class

При выполнении команды ildasm.exe сборки Hello.exe и дважды щелкните значок манифеста в окне дизассемблера IL, выведя следующие выходные данные:

// 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 Hello
{
  .custom instance void [mscorlib]System.Runtime.CompilerServices.CompilationRelaxationsAttribute::.ctor(int32) = ( 01 00 08 00 00 00 00 00 )
  .custom instance void [mscorlib]System.Runtime.CompilerServices.RuntimeCompatibilityAttribute::.ctor() = ( 01 00 01 00 54 02 16 57 72 61 70 4E 6F 6E 45 78   // ....T..WrapNonEx
                                                                                                             63 65 70 74 69 6F 6E 54 68 72 6F 77 73 01 )       // ceptionThrows.
  .hash algorithm 0x00008004
  .ver 0:0:0:0
}
.module Hello.exe
// MVID: {7C2770DB-1594-438D-BAE5-98764C39CCCA}
.imagebase 0x00400000
.file alignment 0x00000200
.stackreserve 0x00100000
.subsystem 0x0003       // WINDOWS_CUI
.corflags 0x00000001    //  ILONLY
// Image base: 0x00600000

В следующей таблице описаны все директивы в манифесте сборки Hello.exe, используемой в этом примере.

Директива Description
.assembly extern <имя_сборки> Определяет другую сборку, содержащую элементы, на которые имеются ссылки в текущем модуле (в этом примере — mscorlib).
.publickeytoken <маркер> Определяет маркер действующего ключа сборки, на которую имеется ссылка.
.ver <номер_версии> Задает номер версии, на которую имеется ссылка.
.assembly <имя_сборки> Задает имя сборки.
.hash algorithm <значение_int32> Задает используемый хэш-алгоритм.
.ver <номер_версии> Задает номер версии сборки.
.module <имя_файла> Задает имена модулей, составляющих сборку. В этом примере сборка состоит только из одного файла.
.subsystem <значение> Указывает требуемую для программы среду приложения. В этом примере значение "3" указывает на то, что выполняемый модуль запускается на консоли.
.corflags В настоящее время представляет собой зарезервированное поле метаданных.

Манифест сборки может содержать несколько различных директив, зависящих от содержимого сборки. Подробный список директив в манифесте сборки см. в документации ecma, особенно "Partition II: Metadata Definition and Semantics" (Определение метаданных и семантика секции III: набор инструкций CIL):

См. также