我知道类实现中的影子成员可能会导致调用“错误”成员的情况,具体取决于我如何转换我的实例,但是对于接口我不认为这可能是一个问题,我发现自己正在编写接口经常这样:
public interface INode
{
IEnumerable<INode> Children { get; }
}
public interface INode<N> : INode
where N : INode<N>
{
new IEnumerable<N> Children { get; }
}
public interface IAlpha : INode<IAlpha>
{ }
public interface IBeta : INode<IBeta>
{ }
我的代码中有一些地方只知道INode
所以 children 也应该是 type INode
。
在其他地方,我想了解特定类型 - 在我的示例IAlpha
和IBeta
接口的实现中,我希望孩子的类型与他们的父母相同。
所以我实现了一个NodeBase
这样的类:
public abstract class NodeBase<N> : INode<N>
where N : INode<N>
{
protected readonly List<N> _children = new List<N>();
public IEnumerable<N> Children
{
get { return _children.AsEnumerable(); }
}
IEnumerable<INode> INode.Children
{
get { return this.Children.Cast<INode>(); }
}
}
在实际实现中没有阴影,仅在接口中。
IAlpha
&的具体实例IBeta
如下所示:
public class Alpha : NodeBase<Alpha>, IAlpha
{
IEnumerable<IAlpha> INode<IAlpha>.Children
{
get { return this.Children.Cast<IAlpha>(); }
}
}
public class Beta : NodeBase<Beta>, IBeta
{
IEnumerable<IBeta> INode<IBeta>.Children
{
get { return this.Children.Cast<IBeta>(); }
}
}
同样,在实现中没有阴影。
我现在可以像这样访问这些类型:
var alpha = new Alpha();
var beta = new Beta();
var alphaAsIAlpha = alpha as IAlpha;
var betaAsIBeta = beta as IBeta;
var alphaAsINode = alpha as INode;
var betaAsINode = beta as INode;
var alphaAsINodeAlpha = alpha as INode<Alpha>;
var betaAsINodeBeta = beta as INode<Beta>;
var alphaAsINodeIAlpha = alpha as INode<IAlpha>;
var betaAsINodeIBeta = beta as INode<IBeta>;
var alphaAsNodeBaseAlpha = alpha as NodeBase<Alpha>;
var betaAsNodeBaseBeta = beta as NodeBase<Beta>;
这些变量中的每一个现在都有正确的强类型Children
集合。
所以,我的问题很简单。使用这种模式的界面成员的阴影是好是坏还是丑陋?为什么?