c# – 用新的隐藏非虚拟成员的替代方法
发布时间:2020-12-15 23:45:09 所属栏目:百科 来源:网络整理
导读:假设我想做这样的事情: class Foo{ public event BarHandler Bar; ...}class FooListT : ListT where T : Foo{ public override void Add(T item) { item.Bar += Bar_Handler; base.Add(item); } private void Bar_Handler ... ...} 但是添加列表 T不是虚拟
假设我想做这样的事情:
class Foo { public event BarHandler Bar; ... } class FooList<T> : List<T> where T : Foo { public override void Add(T item) { item.Bar += Bar_Handler; base.Add(item); } private void Bar_Handler ... ... } 但是添加列表< T>不是虚拟的,所以我不能使用覆盖,我将不得不求助于新的.然而,这并没有提供多态性,我担心可能通过将FooList简单地引用为List而引入的细微错误,这将导致我的事件处理程序没有被添加. 我当前的具体情况是:我想为实现INotifyPropertyChanged的Items子类化ObservableCollection,并在添加/删除这些项目时为这些项目添加/删除事件处理程序.然后,如果Collection中的任何Item发生更改,我将提供一个Event. 我想为我的特定问题以及潜在的一般问题找到解决方案,因为这是我偶然发现的一些想法,来自java背景. 解决方法
而不是扩展List< T>而不是您可以实现
IList<T> 接口并保持内部列表< T>成员变量.这样你就不会破坏现有的List< T>功能并仍然实现与List< T>相同的接口.
例: class FooList<T> : IList<T> where T : Foo { private List<T> m_internalList = new List<T>(); public void Add(T item) { item.Bar += Bar_Handler; m_internalList.Add(item); } // other methods } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |