为什么Java 8接口中不允许使用`private static`字段?

时间:2015-07-16 10:50:48

标签: java interface java-8 private-members

当我尝试编译以下代码时

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在实际上确实有意义时不允许我这样做?

5 个答案:

答案 0 :(得分:15)

在世界之前的Java-8视图中,接口纯粹是用于接口契约,而私有成员纯粹是为了实现而存在,所以这种限制是完全合理的。

在Java-8之后的世界中,接口可以承载行为(但不是状态),因此询问是否应该将其他类的特性应用于接口也是合理的。 (但是,仅仅因为某些东西可能是“合理的”并不意味着它必须得到支持;构建世界通常有不止一种合理的方式。)

在Java 9中,将支持接口中的私有方法。

答案 1 :(得分:9)

接口不是类。他们没有私人国家。即使是界面中的公共记录器也是一种设计气味和滥用界面。

接口中静态字段的用例主要用于编译时常量,而不是有状态对象。

答案 2 :(得分:2)

接口的目标是定义由其他类实现的内容。私有字段没有定义任何内容,因为它在界面外部不可见。因此,在这个结构中没有任何意义。它可能是一些黑客如何使用它(可能来自界面内部类),但无论如何看起来都不是一个好的设计。

如果您实际实现了部分功能,请改用抽象类。

答案 3 :(得分:0)

接口就像是任何类的蓝图,您可以在其中声明您的成员。任何实现该接口的类都负责其定义。 私有成员只能由同一个类成员访问,这在接口方面没有意义。 受保护的成员可以由相同的类成员和继承的类成员访问,但是在接口的情况下我们从不扩展接口,我们实现它。所以任何界面一般只能包含公共方法,

答案 4 :(得分:0)


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);
}