Единственный способ ответить, влияет ли это на вашу производительность или нет, состоит в том, чтобы проверить его: попробуйте один способ, где вы распространяете события, а затем другой, где вы присоединяетесь напрямую.Посмотрите, что быстрее.
При этом я не могу себе представить, что вы обнаружите значительное, если вообще есть, ощутимое влияние на производительность, когда у вас будет несколько последовательных вызовов делегатов вместо одного,Да, делегаты запускаются немного медленнее, чем реальные методы, поэтому при прочих равных условиях добавление большего количества уровней косвенности оказывает большее влияние, чем тот же уровень при обычных вызовах методов, но это пахнет преждевременной оптимизацией.
Ваш подход - это то, что я бы порекомендовал, если бы кто-то спросил, как сделать то, что вам нужно.Пойдите с этим, если это не проблема.
РЕДАКТИРОВАТЬ
В ответ на ваш комментарий к другому ответу, я хотел бы расширить.События C # имеют так называемый «синтаксис свойств».Если реализовано явно в классе, это выглядит примерно так:
private EventHandler eventDelegate;
public event EventHandler MyEvent
{
add { eventDelegate += value; }
remove { eventDelegate -= value; }
}
(На самом деле, он использует Delegate.Combine
, но здесь это несущественно)
Когда вы присоединяетесь к событию, онофактически вызывает код add
, передавая делегат для присоединения как value
;то же самое верно для remove
.
Когда вы используете сокращенный синтаксис события, подобный этому:
public event EventHandler MyEvent;
На самом деле он генерирует код под обложками, который очень похож на тот, который я выложил выше.Однако, если вы сделаете это явно, вы можете делать все что угодно в обработчиках add
и remove
.Это означает, что вы можете перенаправить целевой делегат куда-то еще.В случае другого ответа, он перенаправляет делегата на дочерний объект.
Это будет работать тогда и только тогда, когда верно следующее:
- Существует корреляция 1: 1 между родителем и дочерним элементом, и связанный объект не изменится
- Предоставление ссылки на дочерний объект (как
object
) приемлемо
Если у вас несколько детей, это технически возможно сделать (вы можете просто просмотреть и присоединить их всех в add
и удалить их всех в remove
), но управлять ими гораздо сложнее.Если связанный объект или коллекция объектов могут измениться после того, как событие присоединено, тогда становится практически невозможно координировать.
Кроме того, если ваши события следуют рекомендованным методам для событий (когда вы передаете запускающий объект какsender
), тогда, поскольку вы присоединяете цель непосредственно к дочернему событию, а не вызываете ее самостоятельно, вы будете выставлять ссылку на дочерний объект через этот аргумент.Я понятия не имею, является ли это уместным или приемлемым для вас, , но это то, что следует учитывать .