我经常看到如下代码,想知道是否有任何理由为事件使用局部变量,而不是仅仅使用事件本身。有没有?
var handler = OnQueryComplete;
if (handler != null)
handler(this, new RepositoryEventArgs<T>(results));
是的,绝对 - 它使无效检查变得安全。
如果你只有:
// Bad code, do not use
if (OnQueryComplete != null)
{
OnQueryComplete(this, ...);
}
那么最后一个订阅者可能会在检查和调用之间取消订阅,从而导致NullReferenceException
.
有lots这里的选项:
您可能还想使用Interlocked
确保您获得变量的最新值,以避免内存模型问题。看我的博客文章(包括评论)对此进行更多讨论。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)