反对在接口上声明保护访问成员的论点是什么?例如,这是无效的:
public interface IOrange
{
public OrangePeel Peel { get; }
protected OrangePips Seeds { get; }
}
在此示例中,接口IOrange
将保证实现者至少OrangePips
为其继承者提供一个实例。如果实现者愿意,他们可以将范围扩大到完整public
:
public class NavelOrange : IOrange
{
public OrangePeel Peel { get { return new OrangePeel(); } }
protected OrangePips Seeds { get { return null; } }
}
public class ValenciaOrange : IOrange
{
public OrangePeel Peel { get { return new OrangePeel(); } }
public OrangePips Seeds { get { return new OrangePips(6); } }
}
protected
成员在接口上的意图是为继承者(子类)提供支持合同,例如:
public class SpecialNavelOrange : NavelOrange
{
...
// Having a seed value is useful to me.
OrangePips seeds = this.Seeds;
...
}
(不可否认,这不适用于struct
)
我看不出太大的情况下进行private
或internal
在接口修饰符的,但是同时支持public
andprotected
修饰符似乎是完全合理的。
我将尝试解释 protected
interface
通过将成员与interface
s完全分开s成员:
假设有一个新的C#关键字, support
以强制执行继承者契约,以便我们声明如下:
public support IOrangeSupport
{
OrangePips Seeds { get; }
}
这将使我们能够签订合同,以向其继承者提供受保护的成员:
public class NavelOrange : IOrange, IOrangeSupport
{
public OrangePeel Peel { get { return new OrangePeel(); } }
protected OrangePips Seeds { get { return null; } }
}
这不是特别有用,因为类首先会通过提供protected
成员来暗示此合同。
但是我们也可以这样做:
public interface IOrange : IOrangeSupport
{
...
}
从而适用IOrangeSupport
于所有实现IOrange
并要求它们提供特定protected
成员的类-我们目前无法做到这一点。