class Base {}
abstract class A
{
abstract public List<Base> Items { get; set; }
}
class Derived : Base {}
class B : A
{
private List<Derived> items;
public override List<Derived> Items
{
get
{
return items;
}
set
{
items = value;
}
}
}
编译器表示 B.Items 必须是 Base 元素列表“以匹配重写的成员”A.Items。我怎样才能做到这一点?
最佳答案
你最初试图完成的事情是不可能的 - .NET does not support co(contra)variance for method overload 。属性也是如此,因为属性就是 the pair of methods .
但是您可以使您的类变得通用:
class Base {}
abstract class A<T>
where T : Base
{
abstract public List<T> Items { get; set; }
}
class Derived : Base {}
class B : A<Derived>
{
private List<Derived> items;
public override List<Derived> Items
{
get
{
return items;
}
set
{
items = value;
}
}
}
关于c# - 使用更指定的返回类型(协方差)覆盖抽象属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24561023/