一、默认方法
在JDK1.8之后,接口中可以有默认方法
interface MyInterface1 {
default String getName(){
return "哈哈哈";
}
}
但是这会出现一个问题,就是若一个类它即继承另一个类,又实现了一个接口,而那个接口里面的默认方法的方法名和参数与继承类中的方法名和参数相同,那最后调用方法是到底是调用谁的方法。这里就提到一个原则:
- 接口中默认方法的“类优先”原则
- 若一个接口中定义了一个默认方法,而另一个父类或接口中又定义了一个同名的方法时
- 1.选择父类中的方法。如果一个父类提供了具体的实现,那么接口中具有相同名称和参数的默认方法 会被忽略。
- 2.接口冲突。如果一个父接口提供一个默认方法,而另一个接口也提供了一个具有相同名称个参数列表 的方法(不管方法是否是默认方法),那么必须覆盖该方法来解决冲突。
public class MyClass {
public String getName(){
return "嘿嘿嘿";
}
}
interface MyInterface1 {
default String getName(){
return "哈哈哈";
}
}
class SubClass1 extends MyClass implements MyInterface1{
public static void main(String[] args) {
SubClass1 subClass1 = new SubClass1();
String name = subClass1.getName();
System.out.println(name);
}
}
可以看到,结果输出的是嘿嘿嘿,调用的是父类中的方法。
下面,我们再来看另外一种情况:
如果一个类分别实现了两个接口,但是其中一个父接口提供一个默认方法,而另一个接口也提供了一个具有相同名称个参数列表 的方法(不管方法是否是默认方法),那么必须覆盖该方法来解决冲突,不然就会报错。
我们可以看到代码出现了错误,以下是解决错误之后的代码
interface MyInterface1 {
default String getName(){
return "哈哈哈";
}
}
interface MyInterface2 {
default String getName(){
return "呵呵呵";
}
}
class SubClass2 implements MyInterface1,MyInterface2{
public static void main(String[] args) {
SubClass2 subClass2 = new SubClass2();
String name = subClass2.getName();
System.out.println(name);
}
@Override
public String getName() {
return MyInterface1.super.getName();
}
}
而结果如下图:
二、静态方法
在JDK1.8之后,接口中可以有静态方法
interface MyInterface1 {
default String getName(){
return "哈哈哈";
}
static String show(){
return "Hello World!";
}
}