Java学习(四) interface 接口学习

1.概念

接口的概念在现实生活中使用的很多。例如,计算机上提供的USB接口,专门供USB设备使用,如U盘、USB风扇、USB鼠标、USB键盘等。计算机通过统一的USB接口来提高通用性,使计算机不再需要同时具备U盘专用接口、鼠标专用接口、键盘专用接口等。再如,计算机的主板上提供的PCI插槽,也提供统一的设计规范,使得遵守这个规范的声卡、显卡、网卡都可以插在PCI插槽上。

2.简单概述:

接口就是多个类的公共规范:
接口是一种引用的数据类型,最重要的内容就是其中的:抽象方法。

如何定义一个接口的格式:
public interface 接口名称{
    //接口内容
   }
java7 接口内容包含
1.常量
2.抽象方法
java8 接口内容包含
3.默认方法
4.静态方法
java9 接口内容包含
5.私有方法

接口使用步骤:
1 接口不能直接使用,必须有一个:“实现类”来“实现”接口。
格式:
public class 实现类类名 implements 接口名称{

}
2 接口的实现类必须重写接口中所有的抽象方法
实现方法:去掉abstract 关键字,加上方法体大括号
3 创建实现类对象,进行使用

2.1 抽象方法

接口:

package cn.itcast.demo.object_oriented.Interface.demo01Abstract;

/*
* 在任何版本的java中,接口都可以定义抽象方法
*  格式
*  public abstract 返回值类型  方法名(参数列表);
*
*  注意事项:
*  1。接口当中的抽象方法,修饰符必须是两个固定的关键字:public abstract
*  2. 这两个关键字修饰符,可以选择性省略。
* */
public interface MyInterfaceAbstract {
    //这是一个抽象方法
    public abstract void menthodAbs1();
    //这也是一个抽象方法
    abstract void  methodAbs2();

    public void methodAbs3();

    void methodAbs4();
}

实现类:

package cn.itcast.demo.object_oriented.Interface.demo01Abstract;

public class MyInterfaceImpl implements MyInterfaceAbstract {
    @Override
    public void menthodAbs1() {
        System.out.println("这是第一个抽象方法");
    }

    @Override
    public void methodAbs2() {
        System.out.println("这是第二个抽象方法");
    }

    @Override
    public void methodAbs3() {
        System.out.println("这是第三个抽象方法");
    }

    @Override
    public void methodAbs4() {
        System.out.println("这是第四个抽象方法");
    }
}

main函数:

package cn.itcast.demo.object_oriented.Interface.demo01Abstract;

public class demo01Interfaca {
    public static void main(String[] args) {
        MyInterfaceImpl imp=new MyInterfaceImpl();
        imp.menthodAbs1();
        imp.methodAbs4();
    }
}

2.2默认方法

接口:

package cn.itcast.demo.object_oriented.Interface.demo02Default;

/*
 * 从java8开始,接口里允许定义默认方法
 * 格式:
 * public default 返回值类型 方法名称(参数列表){
 *
 * }
 * 备注:接口当中的默认方法,可以解决接口升级的问题
 * */
public interface MyInterfaceDefault {
    //抽象方法
    public abstract void methodAbs();

    //新添加一个方法, 如果是抽象方法实现类会报错
    public default void methodDefault() {
        System.out.println("我是新来的家伙,干我");
    }
}

实现类A:

package cn.itcast.demo.object_oriented.Interface.demo02Default;

public class MyInterfaceDefaultA implements MyInterfaceDefault {
    @Override
    public void methodAbs() {
        System.out.println("抽象方法实现了 AAAAA");
    }
}

实现类B:

package cn.itcast.demo.object_oriented.Interface.demo02Default;

public class MyInterfaceDefaultB  implements MyInterfaceDefault{
    @Override
    public void methodAbs() {
        System.out.println("抽象方法实现了 BBBBB");
    }

    @Override
    public void methodDefault() {
        System.out.println("我重写了 BBBB");
    }
}

main函数:

package cn.itcast.demo.object_oriented.Interface.demo02Default;

public class demo02Default {
    public static void main(String[] args) {
        //创建实现类对象
        MyInterfaceDefaultA a=new MyInterfaceDefaultA();
        a.methodAbs(); //调用抽象方法,实际运行的是右侧的实现类

        //调用默认方法,如果实现类当中没有,则会向上找接口
        a.methodDefault();
        System.out.println("===============");

        MyInterfaceDefaultB b=new MyInterfaceDefaultB();
        b.methodAbs();
        b.methodDefault();

    }
}

2.3 静态方法

接口:

package cn.itcast.demo.object_oriented.Interface.demo03Static;

/*
* 从java 8 开始,接口当中允许定义静态方法。
* 格式:
* public static 返回值类型 方法名(参数列表){
*
* }
* 提示:就是将abstract或者default换成static即可,带上方法体
* */
public interface MyInterfaceStatic {
    public static void methodStatic(){
        System.out.println("这是静态方法");
    }
}

实现类:

package cn.itcast.demo.object_oriented.Interface.demo03Static;

public class MyInterfaceStaticImpl implements MyInterfaceStatic {
    //因为是静态方法,所以实现类不需要做什么
}

main函数:

package cn.itcast.demo.object_oriented.Interface.demo03Static;

/*
* 注意事项:不能通过接口实现类的对象来调用接口当中的静态方法
* 正确用法:通过接口名称,直接调用其中的静态方法
* 格式:
* 接口名称.静态方法名(参数);
* */
public class demo03Static {
    public static void main(String[] args) {
        //创建接口实现类
        MyInterfaceStaticImpl s=new MyInterfaceStaticImpl();
        //错误的写法
//        s.methodStatic();
        //直接通过接口名称来调用静态方法
        MyInterfaceStatic.methodStatic();
    }
}

2.4 私有方法
* 问题描述:
* 我们需要抽取一个共有方法,用来解决两个默认方法之间重复代码的问题。
* 但是这个公共方法不应该让实现类使用,应该是私有化的
*
* 解决方法:
* 从Java9 开始,接口允许定义私有方法
* 1. 普通私有方法,解决多个默认方法之间重复代码
* 格式
* private 返回值类型 方法名(参数列表){
*   方法体
* }
*
* 2. 静态私有方法,解决多个静态方法之间重复代码问题
* 格式
* private static 返回值类型 方法名 (参数列表){
*   方法体
* }

普通私有方法接口:

package cn.itcast.demo.object_oriented.Interface.demo04Private;

public interface demo01Private {
    public default void methodA (){
        System.out.println("默认方法A");
        methodC();
    }
    public default void methodB (){
        System.out.println("默认方法B");
        methodC();
    }

    private void methodC(){
        System.out.println("111");
        System.out.println("111");
        System.out.println("111");
        System.out.println("111");
        System.out.println("111");
    }
}

静态私有方法接口:
 

package cn.itcast.demo.object_oriented.Interface.demo04Private;

public interface demo01PrivateStatic {
    public static void methodA() {
        System.out.println("私有方法A");
        methodC();
    }

    public static void methodB() {
        System.out.println("私有方法B");
        methodC();

    }

    private static void methodC() {
        System.out.println("111静态私有方法");
    }
}


实现类:

package cn.itcast.demo.object_oriented.Interface.demo04Private;

public class MyInterfacePrivate implements demo01Private {

}

main函数:

package cn.itcast.demo.object_oriented.Interface.demo04Private;

public class PrivateDemo {
    public static void main(String[] args) {
        //普通私有方法调用
        MyInterfacePrivate p=new MyInterfacePrivate();
        p.methodA();
        p.methodB();
        //静态私有方法
        demo01PrivateStatic.methodA();

    }
}

2.5 常量

接口:

package cn.itcast.demo.object_oriented.Interface.demo05Const;

/*
* 接口当中也可以定义“成员变量”,但是必须使用public static final三个关键字进行修饰
* 从效果上看,这其实就是接口的【变量】
* 格式:
* public static final 数据类型 数据名=数据值;
* 备注:
* 一旦使用final关键字修饰,说明不可以改变
*
* 注意事项:
* 1.接口当中的常量,可以省略public static final,注意:不写也照样是这样的
* 2.接口当中的常量,必须进行赋值,不能不赋值
* 3.接口当中的常量名,使用完全大写的字母,用下划线进行分隔,(推荐命名规则)
* */
public interface MyInterfaceConst {
    //这个其实就是一个常量,一旦赋值,不可修改
    public static final int NUM_OF_MY_CLASS=10;
}

main函数:

package cn.itcast.demo.object_oriented.Interface.demo05Const;

public class demo01Const {
    public static void main(String[] args) {
        System.out.println(MyInterfaceConst.NUM_OF_MY_CLASS);
    }
}

2.6 继承和接口

/*
* 使用接口的时候,需要注意:
* 1.接口是没有静态代码块和构造方法的。
* 2.一个的直接父类是唯一的,但是一个类可以同时实现多个接口
* 格式:
* public class MyInterfaceImpl implements MyInterfaceA,MyInterfaceB{
*   //覆盖重写所有抽象方法,
* }
* 3.如果实现类所实现的多个接口当中,存在重复的抽象方法,那么只需要覆盖重写一个即可。
* 4.如果实现类没有覆盖重写所有接口当中的抽象方法,那么实现类就必须就是一个抽象类。
* 5.如果实现类所实现的多个接口当中,存在重复的默认方法,那么实现类一定要对默认方法进行覆盖重写
* */

接口A:

public interface MyInterfaceA {
    //错误写法!接口不能有静态代码块
//    static {
//
//    }
    //错误写法!接口不能有构造方法
//    public MyInterfaceA(){
//
//    }
    public abstract void methodA();

    public abstract void methodAbs();

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

接口B:

public interface MyInterfaceB {

    public abstract void methodB();

    public abstract void methodAbs();

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

实现类:


public class MyInterfaceImpl /*extends Object*/ implements MyInterfaceA, MyInterfaceB {
    @Override
    public void methodA() {
        System.out.println("覆盖重写了MyInterfaceA的A方法");
    }

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

    @Override
    public void methodAbs() {
        System.out.println("覆盖重写了MyInterfaceA,MyInterfaceB都有的Abs方法");
    }

    @Override
    public void methodDefault() {

    }
}

抽象实现类:
 

public abstract class MyInterfaceAbs implements MyInterfaceA, MyInterfaceB {

    @Override
    public void methodA() {
        
    }

    @Override
    public void methodB() {

    }
    

    @Override
    public void methodDefault() {
        
    }
}

细心观察可以发现,抽象实现类是没有覆盖重写methodAbs()这个抽象方法的,但是没有报错。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值