由于条件的原因,不允许JIT执行您在第一部分中讨论的优化。我知道这是在不久前提出来的,但这是无效的。(前一段时间我曾与Joe Duffy或Vance
Morrison进行过核对;我不记得是哪个。)
如果没有volatile修饰符,则所获取的本地副本可能会过时,仅此而已。它不会导致
NullReferenceException。
是的,肯定有比赛条件-但总会存在。假设我们只是将代码更改为:
TheEvent(this, EventArgs.Empty);
现在假设该委托的调用列表有1000个条目。在另一个线程取消订阅列表末尾的处理程序之前,很有可能在列表开头的操作已经执行。但是,该处理程序将仍然执行,因为它将是一个新列表。(代表们是一成不变的。)据我所知,这是不可避免的。
使用空委托当然可以避免无效检查,但不能解决竞争条件。它还不能保证您始终“看到”变量的最新值。



