参考在 Visual Studio 2010 express 中为 C# 编译的这个测试代码
public class Test
{
class Base { }
class Derived : Base { }
void Test1(IEnumerable<Derived> derived)
{
IEnumerable<Base> b = derived; //This works fine using covariance on IEnumerable
}
void Test2<TDerived, TBase>(TDerived derived) where TDerived : TBase
{
TBase b = derived; //This works fine because TDerived is constrained to derive from TBase
}
void Test3<TDerived, TBase>(IEnumerable<TDerived> derived) where TDerived : TBase
{
IEnumerable<TBase> b = derived; //ERROR: paraphrased: Cannot implicitly convert type IEnumerable<TDerived> to IEnumerable<TBase>
}
}
我试图利用 IEnumerable 的协方差将泛型类型参数的可枚举存储在该类型参数被限制继承的类的可枚举中。这以 Test3 为例。请注意,Test1 和 Test2(分别演示编译时类型的协方差和约束类型的分配)都可以正常编译。这是对我不起作用的两种语言功能的组合。
如果我的理解没有缺陷,我可以使用IEnumerable<TBase> b = derived.Cast<TBase>()
并且 100% 确信任何演员都不会失败,所以我确实有一个可用的解决方法。我的问题是,为什么编译器不允许这样做?这是出于某种逻辑原因,编译器中的疏忽还是我没有想到的其他原因而被禁止?