6

我们可以通过两种方式引发事件:

public event EventHandler MyEvent;

private void DoSomething()
{
    ...
    var handler = MyEvent;
    if (handler != null)
        handler(this,EventArgs.Empty);
}

public event EventHandler MyEvent = (o,e) => {} ;

private void DoSomething()
{
    ...
    MyEvent(this, EventArgs.Empty);
}

我更喜欢最后一个。它更短。
我的同事坚持第一个变体。

第一个比第二个有什么优势吗?

4

1 回答 1

11

C# 6 的更新

在 C# 6 中,您只需像这样使用空条件运算符:

PropertyChanged?.Invoke(this, args);

这是Roslyn wiki 推荐的

原始答案

Eric Lippert 有一篇很棒的关于 Events and Races 的博文,如果你还没有的话,你应该阅读一下。

第一个选项可能被认为比第二个更安全,因为事件可能会被设置为 null。有人可能会不小心修改类。此外,如果您反序列化实例,则第二种方法将不起作用(取决于您使用的序列化机制)。

我有时使用辅助方法来引发事件

static class Raiser
{
    public static void Raise<T>(this EventHandler<T> evnt, object sender, T args)
        where T : EventArgs
    {
        if (evnt != null)
        {
            evnt(sender, args);
        }
    }
}

class SomeClass
{
    public event EventHandler<EventArgs> MyEvent;

    private void DoSomething()
    {
        MyEvent.Raise(this, EventArgs.Empty);
    }
}
于 2012-11-29T15:40:58.717 回答