gpt4 book ai didi

c# - 集合的泛型和继承

转载 作者:行者123 更新时间:2023-11-30 21:16:07 31 4
gpt4 key购买 nike

我已经阅读了许多其他相关问题,但仍然不太清楚如何做我们需要做的事情。使用泛型不是必须的,但似乎是我们可能获得所需内容的唯一方法。我们在 .net 3.5 中,所以我们不能使用我认为相关的新 .net 4.0 内容。假设我们有一个具有一些属性和方法的基类 Parent。我们还有一个当前实现 IEnumerable 的 ParentCollection。我们还在此类上添加了其他属性和方法。

我们现在需要从 Parent 继承来创建一个 ChildA。但是我们还需要继承 ParentCollection 来创建 ChildACollection。然后,我们会将 ChildA 的对等类作为 ChildB 和 ChildBCollection。

ChildACollection 和 ChildBCollection 以及它们的项目是唯一实际实例化的东西。 Parent 的东西是抽象的。

ParentCollection 和 Parent 上有一些方法可以返回满足条件并且也可能已被操纵的项目子集。

问题是因为这些方法正在处理集合中的项目,我们希望返回的集合是后代的类型。例如通过 ChildACollection 的实例调用在 ParentCollection 中定义的方法 SomeMethod(),因此子集返回的类型是 List 而不是 List。

有没有办法实现这种功能?

我们正在尝试做的示例伪代码

public class Parent
{
public string PropA { get; set; }
public int PropB { get; set; }

public void DoSomething() { }
}

public class ParentCollection : IEnumerable<Parent>
{
protected List<Parent> _list = new List<Parent>();

public IEnumerator<Parent> GetEnumerator()
{
return _list.GetEnumerator();
}

System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator()
{
return GetEnumerator();
}

public List<Parent> SomeSelectMethod()
{
List<Parent> list = new List<Parent>();

// DO LOGIC HERE TO DETERMINE WHAT ITEMS WILL BE IN LIST

return list;
}

}

public class ChildA : Parent
{
public double PropC { get; set; }

public void DoSomethingElse() { }
}

public class ChildACollection : ParentCollection
{
public void SomeChildMethod() { }
}

public class MyTestClass
{
public void Main()
{
ChildACollection myCollection = new ChildACollection();

//HERE IS THE PROBLEM
List<ChildA> childList = myCollection.SomeSelectMethod();
}

}

基本上我想利用继承,但不想让 ChildACollection 的用户必须不断地将列表中返回的对象引用转换为 ChildA 对象。我的意思是内部列表将具有实际的 ChildA 对象而不是 Parent 对象,但是由于该方法在 ParentCollection 类中,它只知道它是 Parent 或后代类的对象。希望这是有道理的。

帮忙吗?

跟进问题:我需要将此层次结构更深一层(Grandchild)并在 Parent 上添加一个 Add 方法,该方法将创建适当的对象类型并将其添加到列表中,即如果在 ChildCollection 引用上调用 Add,它应该创建并添加一种 Child 类型,并返回对列表中新创建的对象的引用。可能吗?

最佳答案

您可以使用泛型类型参数约束:

    class ParentCollection<T> where T : Parent {
public List<T> SomeSelectMethod()
{
List<T> list = new List<T>();

// can treat T as Parent here

return list;
}
}

class ChildACollection : ParentCollection<ChildA> {
}

class ChildBCollection : ParentCollection<ChildB> {
}

您还可以考虑从 System.Collections.ObjectModel.Collection 继承,这样您就不必实现 IEnumerable。

为了跟进:

我的理解是,您希望父集合上有一个无参数方法 Add(),它创建类型 T 的实例,将其添加到集合中并返回它。一种方法是在 T 上添加一个额外的约束:

class ParentCollection<T> where T : new(),Parent {
public T Add() {
var item = new T();
Add(item);
return item;
}
}

关于c# - 集合的泛型和继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5407967/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com