Использование динамически сгенерированного компоновочного блока

Использование динамически сгенерированного компоновочного блока

Теперь, когда имеется вся программная логика, позволяющая создать и сохранить компоновочный блок, нужен класс для запуска этой логики. Для того чтобы замкнуть цикл, предположим, что в проекте определен второй класс, названный AsmReader. С помощью метода Thread.GetDomain() в Main() получается доступ к текущему домену приложения, который используется для принятия динамически создаваемого компоновочного блока. Получив соответствующую ссылку, вы можете вызвать метод CreateMyAsm().

Чтобы сделать процесс немного более интересным, после завершения вызова CreateMyAsm() будет выполнено динамическое связывание (см. главу 12), обеспечивающее загрузку нового компоновочного блока в память и взаимодействие с членами класса HelloWorld.

using System;

using System.Reflection.Emit;

using System.Reflection;

using System.Threading;

public class Program {

 static void Main(string[] args) {

  Console.WriteLine("********* Чудесный построитель **********");

  Console.WriteLine ("*** динамических компоновочных блоков ***");

  // Получение домена приложения для данного потока.

  AppDomain currAppDomain = Thread.GetDomain();

  // Создание динамического компоновочного блока с помощью f(х).

  СreateMyAsm(currAppDomain);

  Console.WriteLine("-› Завершение создания MyAssembly.dll.");

  // Теперь загрузка нового компоновочного блока из файла.

  Console.WriteLine("-› Загрузка MyAssembly.dll из файла.");

  Assembly a = Assembly.Load("MyAssembly");

  // Получение типа HellоWorld.

  Type hello = a.GetType("MyAssembly.HelloWorld");

  // Создание объекта HelloWorld и вызов нужного конструктора.

  Console.Write("-› Введите сообщение для класса HelloWorld: ");

  string msg = Console.ReadLine();

  object[] ctorArgs = new object[1];

  ctorArgs[0] = msg;

  object obj = Activator.CreateInstance(hello, ctorArgs);

  // Вызов SayHello и вывод возвращенной строки.

  Console.WriteLine("-› Вызов SayHello()");

  Console.WriteLine(" через динамическое связывание.");

  MethodInfo mi = hello.GetMethod("SayHello");

  mi.Invoke(obj, null);

  // Подключение GetMsg(). Метод Invoke() возвращает объект,

  // содержащий возвращенное значение метода.

  mi = hello.GetMethod("GetMsg");

  Console.WriteLine(mi.Invoke(obj, null));

 }

}

В результате создается компоновочный блок .NET, способный создавать компоновочные блоки .NET в среде выполнения.

На этом наш обзор CIL и роли динамических компоновочных блоков завершается. Я надеюсь, эта глава позволила расширить горизонты вашего понимания системы типов .NET, а также синтаксиса и семантики CIL.

Замечание. Обязательно загрузите свой динамически созданный компоновочный блок в ildasm.exe, чтобы выяснить, как функциональные возможности пространства имен System. Reflection.Emit реализуются в программном коде CIL

Исходный код. Проект DynAsmBuilder размещен в подкаталоге, соответствующем главе 15.

Поделитесь на страничке

Следующая глава >

Похожие главы из других книг

Роль манифеста компоновочного блока

Из книги Язык программирования С# 2005 и платформа .NET 2.0. [3-е издание] автора Троелсен Эндрю

Роль манифеста компоновочного блока Наконец вспомним, что компоновочный блок .NET содержит также метаданные, описывающие сам компоновочный блок (эти метаданные называются манифест). Среди всего прочего, в манифесте документируются все внешние компоновочные блоки,


Формат компоновочного блока  .NET

Из книги автора

Формат компоновочного блока  .NET Теперь, когда вы знаете о некоторых преимуществах, обеспечиваемых компоновочными блоками .NET, давайте немного сместим акценты и попытаемся понять то, как устроены компоновочные блоки. С точки зрения внутренней структуры, компоновочный


Необязательные ресурсы компоновочного блока

Из книги автора

Необязательные ресурсы компоновочного блока Наконец, компоновочный блок .NET может содержать любой набор встроенных ресурсов, таких как, например, пиктограммы приложении, графические файлы, звуковые фрагменты или таблицы строк. Платформа .NET обеспечивает поддержку


Создание общедоступного компоновочного блока версии 2.0.0.0

Из книги автора

Создание общедоступного компоновочного блока версии 2.0.0.0 Теперь обновите свой проект CarLibrary, добавив в него определение нового перечня MusicMedia, определяющего четыре возможных музыкальных устройства.// Содержит информацию об источнике музыки.public enum MusicMedia


Представление метаданных компоновочного блока

Из книги автора

Представление метаданных компоновочного блока Окно метаданных ildasm.exe позволяет также просмотреть метаданные самого компоновочного блока, для обозначения которых используется метка Assembly. Следующий фрагмент листинга показывает, что информация, представленная в таблице


Определение текущего компоновочного блока

Из книги автора

Определение текущего компоновочного блока Следующей задачей является определение компоновочного блока, который вы хотите построить. Это делается с помощью директивы .assembly. В простейшем случае компоновочный блок можно определить с помощью простого указания понятного


Создание компоновочного блока .NET в CIL

Из книги автора

Создание компоновочного блока .NET в CIL Теперь, освоив синтаксис и семантику CIL, вы можете закрепить свои знания на практике, построив приложение .NET с использованием только CIL и текстового редактора. Ваше приложение будет состоять из приватного одномодульного *.dll,


Генерирование динамического компоновочного блока

Из книги автора

Генерирование динамического компоновочного блока Чтобы проиллюстрировать процесс определения компоновочного блока .NET в среде выполнения, давайте создадим одномодульный динамический компоновочный блок с именем MyAssembly.dll. В этом модуле будет содержаться класс HelloWorld.


Генерирование компоновочного блока и набора модулей

Из книги автора

Генерирование компоновочного блока и набора модулей Метод начинается с указания минимального набора характеристик компоновочного блока, для чего используются типы AssemblyName и Version (определенные в пространстве имен System.Reflection). Затем с помощью метода уровня экземпляра


Создание общего компоновочного блока

Из книги автора

Создание общего компоновочного блока Сначала создадим общий компоновочный блок, SimpleRemotingAsm.dll, на который будут ссылаться как сервер, так и клиент. В SimpleRemotingAsm.dll определяется единственный MBR-тип с именем RemoteMessageObject, который поддерживает два открытых члена. Метод DisplayMessage()


Создание компоновочного блока сервера

Из книги автора

Создание компоновочного блока сервера Напомним, что компоновочные блоки сервера обслуживают, в частности, и общие компоновочные блоки, содержащие объекты удаленного доступа. Создайте консольную программу с именем SimpleRemoteObjectServer. Роль серверного компоновочного блока


Создание компоновочного блока клиента

Из книги автора

Создание компоновочного блока клиента Теперь, когда у вас есть приемник, который будет обслуживать объекты уда-ленного доступа, остается создать компоновочный блок, который запросит доступ к соответствующим возможностям. Здесь снова создайте простое консольное


Создание общего компоновочного блока

Из книги автора

Создание общего компоновочного блока В ходе нашего обсуждения процесса сериализации объектов в главе 17 мы создали тип JamesBondCar (в дополнение к связанным классам Radio и Car). Библиотека программного кода CarGeneralAsm.dll будет использовать эти типы, поэтому сначала выберите Projects?Add


Создание компоновочного блока сервера

Из книги автора

Создание компоновочного блока сервера Компоновочный блок сервера (CarProviderServer.exe) в рамках метода Main() содержит следующую программную логику.using System;using System.Runtime.Remoting;using System.Runtime.Remoting.Channels;using System.Runtime.Remoting.Channels.Http;using CarGeneralAsm;namespace CarProviderServer { class CarServer {  static void Main(string[] args) {  


Создание компоновочного блока клиента

Из книги автора

Создание компоновочного блока клиента Наконец, рассмотрим приложение клиента, которое будет использовать MBR-тип CarProvider для получения отдельных типов JamesBondCars и типа List‹›. После получения типа от CarProvider вы посылаете его вспомогательной функции UseCar() для обработки.using