为什么 Java 8 接口中不允许使用 `private static` 字段?
Why `private static` field is not allowed in Java 8 interface?
当我尝试编译以下代码时
public interface SomeInterface{
private static Logger logger = Logger.getLogger();
public default void someMethod(){
logger.info("someMethod: default implementation");
}
}
我收到一个错误
Illegal modifier for the interface field SomeInterface.logger; only public, static & final are permitted
当我删除 private
修饰符时,代码会编译,但我不希望包中的其他 类 看到此字段。
为什么 Java 不允许我做这样的事情,虽然它确实有意义?
接口不是 类。他们没有私人国家。即使是界面中的 public 记录器也是一种设计味道和对界面的滥用。
接口中静态字段的用例主要是编译时常量,而不是有状态对象。
接口的目标是定义其他 classes 实现的东西。私有字段不定义任何内容,因为它在界面外不可见。因此,它在这个构造中没有任何意义。如何使用它可能有一些技巧(可能来自界面内部 classes)但无论如何看起来都不是一个好的设计。
如果您实际实现了部分功能,请改用抽象 class。
接口就像任何 class 的蓝图,您可以在其中声明您的成员。任何实现该接口的 class 都对其定义负责。
私有成员只能由相同的 class 成员访问,这在接口方面没有意义。
受保护的成员可以由相同的 class 成员和继承的 class 成员访问,但是在接口的情况下我们从不扩展接口,我们实现它。所以任何接口一般只能包含public个方法,
在Java-8之前的世界观中,接口纯粹是为了接口契约,私有成员的存在纯粹是为了实现,所以这个限制是完全明智的。
在 post-Java-8 的世界里,接口可以承载行为(但不能承载状态),问 类 的其他特性是否应该是合理的也适用于接口。 (然而,仅仅因为某些东西可能 "reasonable" 并不意味着它必须得到支持;通常有不止一种合理的方式来构建世界。)
在Java9中,将支持接口中的私有方法。
public interface SomeInterface {
public default void someMethod() {
SomeInterfaceInternal.logger.info("someMethod: default implementation");
}
}
final class SomeInterfaceInternal {
protected static final Logger logger = LoggerFactory.getLogger(SomeInterface.class);
}
当我尝试编译以下代码时
public interface SomeInterface{
private static Logger logger = Logger.getLogger();
public default void someMethod(){
logger.info("someMethod: default implementation");
}
}
我收到一个错误
Illegal modifier for the interface field SomeInterface.logger; only public, static & final are permitted
当我删除 private
修饰符时,代码会编译,但我不希望包中的其他 类 看到此字段。
为什么 Java 不允许我做这样的事情,虽然它确实有意义?
接口不是 类。他们没有私人国家。即使是界面中的 public 记录器也是一种设计味道和对界面的滥用。
接口中静态字段的用例主要是编译时常量,而不是有状态对象。
接口的目标是定义其他 classes 实现的东西。私有字段不定义任何内容,因为它在界面外不可见。因此,它在这个构造中没有任何意义。如何使用它可能有一些技巧(可能来自界面内部 classes)但无论如何看起来都不是一个好的设计。
如果您实际实现了部分功能,请改用抽象 class。
接口就像任何 class 的蓝图,您可以在其中声明您的成员。任何实现该接口的 class 都对其定义负责。 私有成员只能由相同的 class 成员访问,这在接口方面没有意义。 受保护的成员可以由相同的 class 成员和继承的 class 成员访问,但是在接口的情况下我们从不扩展接口,我们实现它。所以任何接口一般只能包含public个方法,
在Java-8之前的世界观中,接口纯粹是为了接口契约,私有成员的存在纯粹是为了实现,所以这个限制是完全明智的。
在 post-Java-8 的世界里,接口可以承载行为(但不能承载状态),问 类 的其他特性是否应该是合理的也适用于接口。 (然而,仅仅因为某些东西可能 "reasonable" 并不意味着它必须得到支持;通常有不止一种合理的方式来构建世界。)
在Java9中,将支持接口中的私有方法。
public interface SomeInterface {
public default void someMethod() {
SomeInterfaceInternal.logger.info("someMethod: default implementation");
}
}
final class SomeInterfaceInternal {
protected static final Logger logger = LoggerFactory.getLogger(SomeInterface.class);
}