Should I instantiate a new delegate or not?

2019-01-24 14:21发布

I just realized I can add an event handler in two ways:

Consider an event handler like so:

private void MyEventHandler()
{}

Method 1: Instantiate a new delegate

MyObject.MyEvent += new Action(MyEventHandler);

Method 2: Add event handler without instantiating a new delegate

MyObject.MyEvent += MyEventHandler;

Is there any difference in between these two implementations that should be considered?

2条回答
Explosion°爆炸
2楼-- · 2019-01-24 15:02

There is no difference, the generated IL is the same. The shorter form was introduced in .net/c# 2.0 as a convenience function, although Visual Studio still does the first form on Tab Completion.

See this question for some more info.

查看更多
戒情不戒烟
3楼-- · 2019-01-24 15:02

I believe that while you can unsubscribe from the second, you'd not be able to unsubscribe from the first.

That would be a pretty important distinction. There is really nothing to be gained by wrapping it in an Action in any case.

update

Okay, I think I misunderstood what you were doing. If the event is declared as

public event Action MyEvent;

then the two subscriptions are equivalent, the second being shorthand for the first.

There are actually other ways to add event handlers:

MyObject.MyEvent += delegate { MyEventHandler(); };

MyObject.MyEvent += () => MyEventHandler();

In these cases, you would not be able to unsubscribe. In these examples, the delegates are calling the handler method, but usually when employing this method it is to avoid having to create separate handler methods -- the handler code goes right in the anonymous method.

查看更多
登录 后发表回答