有点惊讶为什么这不起作用
这是编译器的限制还是不支持它是否合理?
public class Class1<T> : IInterface
where T : Test2
{
public T Test { get; private set; }
}
public class Test2
{
}
internal interface IInterface
{
Test2 Test { get; }
}
我得到的错误是
'ClassLibrary1.Class1<T>' does not implement interface member 'ClassLibrary1.IInterface.Test'.
'ClassLibrary1.Class1<T>.Test' cannot implement 'ClassLibrary1.IInterface.Test' because it does not have the matching return type of 'ClassLibrary1.Test2'.
答案 0 :(得分:9)
有关更多更正,请明确实现接口:
public class Class1<T> : IInterface
where T : Test2
{
public T Test { get; private set; }
Test2 IInterface.Test
{
get { ... }
}
}
然后你可以避免编译错误。
答案 1 :(得分:5)
由于T
可以是从Test2
派生的任何类型,Class1
不会完全实现IInterface
。
更一般地说,通过返回协变类型来实现接口是不可能的:
interface IFoo
{
object Bar { get; }
}
class Broken : IFoo
{
string Bar { get; } // you cannot expect to implement IFoo this way!
}
答案 2 :(得分:1)
将您的界面更改为此,它将编译:
public class Class1<T> : IInterface<T>
where T : Test2
{
public T Test { get; private set; }
}
public class Test2
{
}
internal interface IInterface<T>
where T : Test2
{
T Test { get; }
}
答案 3 :(得分:1)
你是否可以使你的界面通用,例如。
public class Class1<T> : IInterface<T>
where T : Test2
{
public T Test { get; private set; }
}
public class Test2
{
}
internal interface IInterface<T>
{
T Test { get; }
}
或者你是否试图避免界面上的泛型(这也有很好的理由!)
答案 4 :(得分:1)
接口说属性Test是Test2 Type。在您的实现中Class1属性Test是继承Test2的一些类,但不完全是它。 要做你想做的事,你需要写下这样的东西:
public class Class1<T> : IInterface
where T : Test2
{
private T _test;
public Test2 Test { get{return _test} }
}
public class Test2
{
}
internal interface IInterface
{
Test2 Test { get; }
}