我有一种情况,我希望编译器的行为得到解释。给出一小段代码:
interface IFoo<T>
{
T Get();
}
class FooGetter : IFoo<int>
{
public int Get()
{
return 42;
}
}
以下代码将编译并运行:
static class FooGetterGetter
{
public static IFoo<T> Get<T>()
{
return (IFoo<T>)new FooGetter();
}
}
如果我们更改了Foo
类的签名并添加了sealed
关键字:
sealed class FooGetter : IFoo<int> // etc
然后,我在下面的行上得到一个编译器错误:
return (IFoo<T>)new FooGetter();
地址为:
无法将类型“MyNamespace.FooGetter”转换为“MyNamespace.IFoo”
有人能解释一下这里发生的关于sealed
关键字的事情吗?这是Visual Studio2010中针对.NET 4项目的C# 4。
更新:有趣的是,当我想知道为什么下面的代码在应用sealed
时会修复它时,我偶然发现了这部分行为:
return (IFoo<T>)(IFoo<int>)new FooGetter();
更新:只是为了澄清,当请求的T
类型与具体类型使用的T
类型相同时,它都运行得很好。如果类型不同,则强制转换在运行时会失败,并显示如下内容:
无法将'MyNamespace.StringFoo‘类型的对象强制转换为'MyNamespace.IFoo`1System.Int32’类型
在上面的例子中,StringFoo : IFoo<string>
和调用者请求获取一个int
。
https://stackoverflow.com/questions/8912542
复制相似问题