接口及使用注意事项

接口

接口(interface)在JAVA编程语言中是一个抽象类型,是抽象方法的集合,以interface来声明。
定义一个接口的格式:

public interface 接口名称{
    //接口内容
}

对于接口的一些解释

接口都能定义抽象方法
格式:

	public abstract 返回值类型 方法名称();

1.接口当中的抽象方法,修饰符必须是两个固定的关键字: public abstract。
2.这两个关键字修饰符,可以选择性地省略。

当类实现接口的时候,类要实现接口中所有的方法。否则,类必须声明为抽象的类。
类使用implements关键字实现接口。在类声明中,Implements关键字放在class声明后面。
格式:

public class 类名称 implements 接口名称{
	...
}

从Java 8 开始,接口中允许定义默认方法
格式:

public default 返回值类型 方法名称(参数列表){
	方法体
}

接口当中的默认方法,可以解决接口升级的问题,并且也可以被覆盖重写。

从Java 8 开始,接口当中允许定义静态方法
格式:

public static 返回值类型 方法名称(参数列表){
    方法体
}

注意:调用接口中静态方法直接通过 接口名称.静态方法名 来调用。

从Java9开始允许将方法定义为 private,使得某些复用的代码不会把方法暴露出去。

Java 9私有接口方法

接口中可以定义"成员变量",但是必须用 public static final 三个关键字修饰。
从效果上看,其实就是接口的"常量"。
格式:

public static final 数据类型 数据名称 = 数据值;

注意事项:

  1. 接口中的"常量",可以省略public static final,但是省略与否效果都一样。
  2. 接口中的"常量",必须赋值。
  3. 接口中的"常量"名称使用完全大写使用"下划线_"分割
public interface MyInterfaceConst {
    //一旦被赋值,就不能修改
    public static final int NUM_OF_CONST = 10;
}

实现多个接口时注意事项

注意事项:
1.接口中不能有静态代码块和构造方法
2.一个类的直接父类有且仅有一个,但一个类可以同时实现多个接口
格式:

public class MyInterfaceImpl implements MyInterfaceA,MyInterfaceB{
    覆盖重写接口中所以抽象方法
}

3.如果实现类所实现的多个接口当中,存在重复的抽象方法,那么只需要覆盖重写一次即可。

4.如果实现类没有覆盖重写所有接口当中的所有抽象方法,那么实现类就必须是一个抽象类(class前加上abstract)。

public abstract class MyInterfaceAbs implements MyInterfaceA,MyInterfaceB{
    @Override
    public void methodA() {

    }

    /*接口B中未被重写的方法
    @Override
    public void methodB() {
    }
     */
}

5.如果实现类实现的多个接口当中,存在重复的默认方法,那么实现类一定要对冲突的默认方法进行覆盖重写。

interface MyInterfaceA {
    public abstract void methodA();

    public abstract void methodAbs();

    public default void methodDefault(){
        System.out.println("默认方法AAA");
    }
}



interface MyInterfaceB {

    public abstract void methodB();

    public abstract void methodAbs();

    public default void methodDefault(){
        System.out.println("默认方法BBB");
    }
}



MyInterfaceImpl implements MyInterfaceA,MyInterfaceB{

    @Override
    public void methodA() {
        System.out.println("覆盖重接了A方法");
    }

    @Override   
    public void methodAbs() {
        System.out.println("覆盖重写了A B接口都有的抽象方法");
    }

    @Override
    public void methodDefault() {
        System.out.println("对多个接口中冲突的默认方法进行覆盖重写");
    }

    @Override
    public void methodB() {
        System.out.println("覆盖重接了B方法");
    }
}

6.一个类如果直接父类当中的方法,和接口当中的默认方法产生了冲突,优先用父类当中的方法。

public class Fu {
    public void method(){
        System.out.println("父类方法");
    }
}
public interface MyInterface {
    public default void method(){
        System.out.println("接口默认方法");
    }
}

public class Zi extends Fu implements MyInterface{

}
public class Demo02Interface {
    public static void main(String[] args) {
        Zi zi = new Zi();
        zi.method();  //优先父类方法
    }
}

在这里插入图片描述
注:
1.类与类之间是单继承的。直接父类只有一个。
2.类与接口之间是多实现的。一个类可以实现多个接口。
3.接口与接口之间是多继承的。

注意事项:
1.多个父接口当中的抽象方法如果重复,没关系。
2.多个父接口当中的默认方法如果重复,那么子接口必须进行默认方法的覆盖重写,而且需带上default关键字。

public interface MyInterfaceA {

    public abstract void methodA();

    public abstract void methodCommon();
    
    public default void methodDefault(){
        System.out.println("默认方法A");
    }
}
public interface MyInterfaceB {

    public abstract void methodB();

    public abstract void methodCommon();

    public default void methodDefault(){
        System.out.println("默认方法B");
    }
}
public interface MyInterface extends MyInterfaceA,MyInterfaceB{

    public abstract void method();
	//需要对父类接口重名默认方法进行覆盖重写
    @Override
    default void methodDefault() {
        System.out.println("默认方法");
    }
}
/*
这个子接口中实际有四个抽象方法:
methodA 来源于接口A
methodB 来源于接口B
methodCommon 同时来源于接口A和B
method 本身自己定义
 */
//实现类对子类接口进行实现,需要将子类接口中的所有抽象方法进行覆盖重写
public class MyInterfaceImpl implements MyInterface{
    @Override
    public void method() {

    }

    @Override
    public void methodA() {

    }

    @Override
    public void methodB() {

    }

    @Override
    public void methodCommon() {

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值