我对 C# 的理解是,子类不能覆盖父类的方法实现,除非该方法被标记为虚拟。如果子类声明了一个与父方法同名但没有标记为虚拟的方法,它只是隐藏了该方法,因此如果从父类型的引用调用该方法,它将调用父方法,如果它是从子类类型的引用中调用它将调用子类方法。但是,我在 C# 库中发现一种情况似乎破坏了这种行为。
Collection<T>
声明一个public void Add(T item)
方法。此方法不是虚拟的,因此子类中的实现不应覆盖其行为。然而,下面的测试产生了矛盾的结果。
public void Test()
{
ObservableCollection<String> strings1 = new ObservableCollection<String>();
strings1.CollectionChanged += OnCollectionChanged;
strings1.Add("One String");
Collection<String> strings2 = strings1;
strings2.Add("Another String");
}
public void OnCollectionChanged(Object source,
NotifyCollectionChangedEventArgs e)
{
Console.WriteLine("Collection Change!");
}
由于该NotifyCollectionChanged
行为未在Collection
类中实现,并且ObservableCollection
该类不能覆盖该类的Add
方法,因此Collection
我希望仅当对象被引用为 a 时才会触发集合更改事件ObservableCollection<String>
,而不是当它被引用为 a 时Collection<String>
。但是有两个事件被触发。结果是:
Collection Change!
Collection Change!
谁能解释这里发生了什么?