接口体回顾
(1)JDK7及以前:只能定义全局常量和抽象方法
- ①全局常量:public static final 修饰(可省略,但只能是public)
- ②抽象方法:public abstract 修饰 (可省略,但只能是public abstract)
(2)JDK8:能定义全局常量、抽象方法、静态方法、默认方法
1.静态方法
- 抽象方法没有方法体,静态方法有方法体
- 静态方法修饰符不一定是public,可以是其他权限修饰符
- 接口中的静态方法不能通过类对象访问。若需要对象访问该方法,则需要在实现类中写一个同名同参数的方法(此时实现类中的方法可以视为一个新方法。不能说实现类重写了接口中的方法,因为重写是子类重写父类中的方法,而类与接口是并列关系,不是继承关系,不能说是重写)
interface Port1
{
public static void method1()
{
System.out.println("我是静态方法");
}
}
class KindA implements Port1 {
}
class KindB implements Port1
{
public static void method1()
{
System.out.println("我是被实现类覆盖的静态方法");
}
}
public static void main(String[] args)
{
KindA a=new KindA();
//a.method1(); 报错
Port1.method1();//我是静态方法
KindB b=new KindB();
b.method1();//我是被实现类覆盖的静态方法
Port1.method1();//我是静态方法
}
2.默认方法
- 抽象方法没有方法体,默认方法有方法体
- 默认方法权限修饰符只能是 default
- 可以通过实现类对象调用接口中的默认方法。不能通过接口直接调用默认方法。
interface Port2
{
default void method2()
{
System.out.println("我是默认方法");
}
}
class KindC implements Port2{
}
public static void main(String[] args)
{
KindC c=new KindC();
c.method2();//我是默认方法
//Port2.method2(); 报错
}
- 类优先原则:如果子类(或实现类)继承的父类和实现的接口中声明了同名同参数的默认方法,子类在没有重写此方法的情况下,默认调用的是父类中的同名同参数的方法。
interface Port2
{
default void method2()
{
System.out.println("我是默认方法");
}
}
class SuperC
{
public void method2()
{
System.out.println("我是父类中的同名同参数方法");
}
}
class KindC extends SuperC implements Port2{
}
public static void main(String[] args)
{
KindC c=new KindC();
c.method2();//我是父类中的同名同参数方法
//Port2.method2(); 报错
}
- 接口冲突:如果实现类实现了多个接口,而这多个接口中定义了同名同参数的默认方法,那么在实现类没有重写此方法的情况下这就需要我们必须在实现类中重写此方法