Java接口中的方法应该使用或不使用公共访问修饰符来声明?
当然,从技术上讲,这并不重要。实现接口的类方法总是公共的。但是什么是更好的约定呢?
Java本身在这方面并不一致。参见Collection vs. Comparable或Future vs. ScriptEngine。
Java接口中的方法应该使用或不使用公共访问修饰符来声明?
当然,从技术上讲,这并不重要。实现接口的类方法总是公共的。但是什么是更好的约定呢?
Java本身在这方面并不一致。参见Collection vs. Comparable或Future vs. ScriptEngine。
当前回答
我宁愿跳过它,我在某处读到,接口是默认的,公共的和抽象的。
令我惊讶的是,这本名为《Head First Design Patterns》的书使用了公共接口声明和接口方法……这让我再次反思,我找到了这个职位。
无论如何,我认为多余的信息应该被忽略。
其他回答
JLS明确了这一点:
允许为接口中声明的方法冗余地指定公共和/或抽象修饰符,但出于风格考虑,不建议这样做。
在Java接口中应该省略公共修饰符(在我看来)。
因为它没有添加任何额外的信息,它只是把注意力从重要的东西上转移开。
大多数风格指南会建议你去掉它,但是当然,最重要的事情是在你的代码库中保持一致,特别是对于每个接口。下面的例子很容易让Java不是100%流利的人感到困惑:
public interface Foo{
public void MakeFoo();
void PerformBar();
}
尽管这个问题很久以前就被问过了,但我觉得一个全面的描述可以解释为什么没有必要在方法之前使用公共抽象,在接口的常量之前使用公共静态final。
首先,接口用于为一组不相关的类指定通用方法,其中每个类都有唯一的实现。因此,不可能将访问修饰符指定为private,因为它不能被其他要重写的类访问。
第二,虽然可以初始化接口类型的对象,但接口是由实现它的类实现的,而不是继承的。由于接口可能由不在同一个包中的不同不相关的类实现(实现),因此受保护访问修饰符也无效。因此,对于访问修饰符,我们只剩下公共选择。
第三,接口没有任何数据实现,包括实例变量和方法。如果在逻辑上有理由在接口中插入实现的方法或实例变量,那么它必须是继承层次结构中的超类,而不是接口。考虑到这一点,由于没有方法可以在接口中实现,因此接口中的所有方法都必须是抽象的。
第四,Interface只能包含常量作为它的数据成员,这意味着它们必须是final常量,当然final常量被声明为静态以只保留它们的一个实例。因此,静态final也是接口常量的必须值。
因此,总的来说,虽然在接口的方法之前使用公共抽象,在接口的常量之前使用公共静态final是有效的,但由于没有其他选项,因此被认为是多余的,不使用。
我宁愿跳过它,我在某处读到,接口是默认的,公共的和抽象的。
令我惊讶的是,这本名为《Head First Design Patterns》的书使用了公共接口声明和接口方法……这让我再次反思,我找到了这个职位。
无论如何,我认为多余的信息应该被忽略。
我将避免使用默认应用的修饰符。正如所指出的,它会导致不一致和混乱。
我见过的最糟糕的是一个方法声明为抽象的接口…