所以我有一个
BaseClass
和几个从基类继承的子类
ChildClass1
ChildClass2
我有ObservableCollections
个子类需要进行排序,我无法创建新的ObservableCollection<ChildClas1>
。
所以我写了一个函数
private void Reorder(ObservableCollection<BaseClass>)
{
//sort the collection in place
}
然后我做Reorder(ObservableCollection<ChildClass1>)
编译器抱怨它无法转换
System.Collections.ObjectModel.ObservableCollection<ChildClass1>
至ObservableCollection<BaseClass>
我将把编译器的内容用于它,但是如何在不必为每个子类型重复我的重新排序功能的情况下实现这一目标呢?
答案 0 :(得分:6)
我会用编译器的话来说明它
许多Q&amp; As SO中讨论了为什么不能传递一种类型的集合来代替另一种类型的集合的原因 - 例如,here。
如何在不必为每个子类型重复我的重新排序功能的情况下实现这一目标?
一种方法是对集合元素的类型进行Reorder
泛型,并在type参数中添加一个约束,以指定对象必须从您的基类派生:
void Reorder<T>(ObservableCollection<T> collection) where T : BaseClass {
...
}