WeakReference和事件处理

Che*_*ian 31 .net c# design-patterns weak-references

通过WeakReference实现事件处理是一个好习惯,如果该事件是唯一持有引用的东西,并且我们需要对象进行垃圾回收?

作为一个论点:

人们说,如果你订阅某些东西,你有责任取消订阅,你应该这样做.

Ed *_*all 14

尽可能养成从事件中取消订阅的习惯,但有时候没有明显的"清理"方法可以完成.我们最近发布了一篇关于这个主题的博客文章 它包含的方法可以轻松订阅具有WeakReference的事件.


Ily*_*kov 10

弱委托模式应该在CLR中存在.正常事件表现出"在你活着时通知我"的语义,而我们经常需要"在我活着时通知我".只是在WeakReference上有委托是错误的,因为委托也是一个对象,即使当接收者仍然存在并且有传入的引用时,委托本身只被所述WeakReference引用并将立即收集.有关实现的示例,请参阅此旧帖子.


Gle*_*ock 6

弱引用本身就没有解决问题,因为委托持有引用.在Prism(www.microsoft.com/compositewpf)附带的复合应用程序库中,有一个可以从源中提取的WeakDelegate类.WeakDelegate基本上是反射并且仅在一段时间内创建一个委托然后释放它,从而没有任何指针.在CAL中,它由EventAggregator类使用,但您可以自由地将其删除,因为它在MS-PL下.


Sam*_*Kim -2

虽然您的建议解决了一组问题(事件引用管理和内存泄漏预防),但它可能会带来一组新的问题。

我看到的一个问题是,在事件处理过程中,如果源对象被垃圾收集(因为它仅由弱引用保存),则任何访问源对象的代码都将导致空引用异常。您可以认为事件处理程序要么不应该访问源对象,要么它必须具有强引用,但可以认为这可能是比您首先尝试解决的问题更糟糕的问题。