我正在编写一个带有类型参数 T 的通用抽象类 A,我打算用类 B 派生它。
A 有一个数据成员 mX,它是类 C 的一个实例,带有一个通用函数。这个通用函数 GetAllOfType() 有一个类型参数 T。这个类型参数被限制到第三个类 D。GetAllOfType() 搜索 D 实例的容器,其中包括 D 的派生类的实例,并返回T 类型的子集(因此对 D 的约束)。
D 类本身没有特定的数据成员 int mY,但 D 的某些派生类有,例如 E 和 F。
public class D
{
}
public class E : D
{
public int mY;
}
public class F : D
{
public int mY;
}
public class C
{
public T[] GetAllOfType<T>() where T : D
{ ... }
}
public class A<T>
{
private C mX;
...
}
public class B : A<E>
{
...
}
所以这是我的问题开始的地方:
B 类用于继承和实现 A 类的参数类型是 D 的派生类。我正在尝试在 A 类中编写一个函数 Foo,该函数通过 GetAllOfType() 枚举并访问 E、F 或任何其他类型的成员 mY有一个 myY 的成员。
public class A<T>
{
private C mX;
protected Foo()
{
foreach (var c in mX.GetAllOfType<T>())
{
c.mY = 0;
}
}
}
public class B : A<E>
{
public Bar()
{
Foo();
}
}
但是,问题是 GetAllOfType() 受到约束,并且我也因未约束 A 类而收到错误消息。
我试过像这样约束 A :
public class A<T> where T : D
但是我遇到了编译时错误:
键入
T' does not contain a definition for
mY' 并且找不到扩展方法mY' of type
T'(您是否缺少 using 指令或程序集引用?)
我还尝试限制到多个派生类:
public class A<T> where T : E, F
但是我也遇到了以下错误:
类类型约束“F”必须列在任何其他约束之前。考虑将类型约束移动到约束列表的开头
我试过切换它们:
public class A<T> where T : F, E
同样,结果是相同的错误,但将 F 切换为 E。
我正在尝试的可能吗?我究竟做错了什么?
同样,我无法更改 C、D、E 和 F 类的任何内容。