Java接口方法默认为public abstract,无需显式声明;default方法用于向后兼容,static方法属接口本身;接口变量自动为public static final常量;泛型需谨慎使用以确保类型安全。
Java 接口里的方法默认就是 public abstract,显式写出来反而多余,编译器会直接报错。比如下面这段代码是非法的:
public interface Service {
private void doWork(); // 编译错误:interface method cannot be private
protected int getValue(); // 编译错误:interface method cannot be protected
public abstract String
getName(); // 合法但冗余,不推荐
}
正确写法只写方法签名即可:
public interface Service {
String getName(); // 自动视为 public abstract
void doWork();
int getValue();
}
public 和 abstract,JVM 仍按抽象方法处理final、synchronized、native 等修饰符default 方法用于向后兼容——在不破坏已有实现类的前提下扩展接口;static 方法则属于接口本身,不能被实现类继承,只能通过接口名调用。
public interface Logger {
void log(String msg); // 抽象方法
default void info(String msg) {
log("[INFO] " + msg);
}
static void error(String msg) {
System.err.println("[ERROR] " + msg);
}
}
default 方法可被实现类直接调用或重写,适用于通用逻辑下沉static 方法不能被重写,也不能访问 this,适合工具型功能(如工厂构造、常量转换)default 方法,实现类必须显式覆写,否则编译失败接口里声明的变量自动加上 public static final,哪怕你只写 int MAX_SIZE = 100;。试图修改会触发编译错误。
public interface Config {
int MAX_SIZE = 100; // 等价于 public static final int MAX_SIZE = 100;
String ENV = "prod";
}
private String name;),会编译失败public static final List LIST = new ArrayList(); ),容易引发并发或误修改问题接口一旦发布,方法签名就很难改。泛型擦除会让某些设计在运行时失效,比如 List 和 List 在字节码中都是 List。
public interface Processor{ T process(T input); // 安全:类型由调用方绑定 List getNames(); // 明确,无歧义 List> getItems(); // 比裸写 List 更安全,避免 add() 风险 }
List),应写 List 或 List>
instanceof 对泛型无效)void execute(); 里。