加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读