我有一个泛型类,我正在尝试实现隐式类型转换.虽然它主要起作用,但它不适用于界面转换.经过进一步调查,我发现存在编译器错误:"来自接口的用户定义转换"适用.虽然我知道在某些情况下应该强制执行,但我正在尝试做的事情似乎是合法的案例.
这是一个例子:
public class Foowhere T : IBar { private readonly T instance; public Foo(T instance) { this.instance = instance; } public T Instance { get { return instance; } } public static implicit operator Foo (T instance) { return new Foo (instance); } }
使用它的代码:
var concreteReferenceToBar = new ConcreteBar(); IBar intefaceReferenceToBar = concreteReferenceToBar; FooconcreteFooFromConcreteBar = concreteReferenceToBar; Foo fooFromConcreteBar = concreteReferenceToBar; Foo fooFromInterfaceBar = intefaceReferenceToBar; // doesn't work
有没有人知道一个解决方法,或者任何人都能以令人满意的方式解释为什么我不能施展 interfaceReferenceToBar
隐式地Foo
,因为在我的情况下它没有被转换,只包含在Foo中?
编辑: 看起来协方差可能提供救赎.我们希望C#4.0规范允许使用协方差隐式转换接口类型.
你不能这样做的原因是因为它在C#语言规范中是特别禁止的:
如果满足以下所有条件,则允许类或结构声明从源类型S到目标类型T的转换:
...
S和T都不是
object
或接口类型.
和
不允许用户定义的转换从接口类型转换或转换为 接口类型.特别是,此限制确保在转换为接口类型时不会发生用户定义的转换,并且只有在转换 的对象实际实现指定的接口类型时,才能成功转换为 接口类型.
资源