Csharp/C#教程:是否有任何理由在提升之前将事件分配给局部变量?分享


是否有任何理由在提升之前将事件分配给局部变量?

我经常看到如下代码,并想知道是否有任何理由为事件使用局部变量,而不是仅使用事件本身。 在那儿?

var handler = OnQueryComplete; if (handler != null) handler(this, new RepositoryEventArgs(results)); 

是的,绝对 – 它使无效检查安全。

如果你有:

 // Bad code, do not use if (OnQueryComplete != null) { OnQueryComplete(this, ...); } 

然后最后一个订阅者可以在检查和调用之间取消订阅,从而导致NullReferenceException

这里有很多选择:

您可能还希望使用Interlocked来确保获得变量的最新值,以避免内存模型问题。 有关此问题的更多讨论,请参阅我的博客文章(包括评论) 。

上述就是C#学习教程:是否有任何理由在提升之前将事件分配给局部变量?分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/cdevelopment/1031974.html

(0)
上一篇 2022年1月14日
下一篇 2022年1月14日

精彩推荐