Шрифт:
Отправка событий вызывающей стороне выполняется с помощью простого указания имени события и всех обязательных параметров, предусмотренных в определении соответствующего делегата. Вы должны проверить событие на значение null перед тем, как вызывать набор методов делегата, чтобы гарантировать регистрацию события вызывающей стороной. С учетом этого предлагается новый вариант метода Accelerate для типа Car.
Мы наделили автомобиль способностью посылать два типа пользовательских событии, избавив себя от необходимости определять пользовательские функции регистрации. Немного позже мы приведем пример использования нашего нового автомобили, но сначала более подробно рассмотрим архитектуру событий.
Глубинный механизм событий
Событие в C# представляется двумя скрытыми общедоступными методами, один из которых имеет префикс add_, а другой – префикс remove_. За этими префиксами следует имя события. Например, событие Exploded транслируется в пару CIL-методов с именами add_Exploded и remove_Exploded. Кроме приведения к методам add_XXX и remove_XXX, определение события на уровне CIL связывает данное событие с соответствующим делегатом.
Взгляните на CIL-инструкции для add_AboutToBlow, и вы обнаружите программный код, почти идентичный программному коду вспомогательного метода OnAboutToBlow из рассмотренного выше примера CarDelegate (обратите внимание на строку с вызовом Delegate.Combine).
В соответствии с ожиданиями, метод remove_AboutToBlow неявно (опосредованно) вызывает Delegate.Remove и приблизительно соответствует определенному выше вспомогательному методу RemoveAboutToBlow.
Наконец, программный код CIL, представляющий само событие, использует директивы .addon и .removeon для отображения имен в соответствующие имена вызываемых методов add_XXX и remove_XXX.