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()这个抽象方法的,但是没有报错。