为什么 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);
}