####接口
是一种引用类型,方法的集合,接口里面的主要内容就是封装方法,根据不同的jdk 包含的内容也不同
java7 包含:常量、抽象方法
java8 包含:常量、抽象方法、默认方法、静态方法
java9 包含:常量、抽象方法、默认方法、静态方法、私有方法。
接口的定义:使用interface关键字,它也会被翻译成**.class**文件,但是它并不是类。
接口的使用:
1.它不能创建对象,不能直接使用,而是用implements关键字实现,类似于被继承。
格式:
public interface 接口名称{
//抽象方法
//默认方法
//静态方法
//私有方法
}
public class 实现类名称 implements 接口名称{
.............
}
2.接口的实现类必须覆盖重写接口中所有的抽象方法。
方式:去掉abstract关键字,加上方法体大括号。
3.创建实现类的对象进行使用。
4.如果实现类并没有覆盖重写接口中的所有方法,那么这个类自己必须是抽象类。
代码演示:
1建一个interface接口 MyInterfaceAbstract.java
使用abstract关键字修饰 可以省略 但是不推荐。没有方法体 该方法是供子类实现使用的。
public interface MyInterfaceAbstract{
//这是抽象方法,标准的写法,
public abstract void method1();
//这也是抽象方法
abstract void method2();
//这还是抽象方法
public void method3();
//这...依然是抽象方法
void method4();
}
2.创建MyInterfaceAbstractImpl.java 实现MyInterfaceAbstract.java
public class MyInterfaceAbstractImpl implements MyInterfaceAbstract{
//此时按Alt+Enter 选择Implement methods自动重写功能
@Override
public void methodAbs1(){
System.out.println("这是第1个方法");
}
@Override
public void methodAbs2(){
System.out.println("这是第2个方法");
}
@Override
public void methodAbs3(){
System.out.println("这是第3个方法");
}
@Override
public void methodAbs4(){
System.out.println("这是第4个方法");
}
}
3.创建实现类对象进行使用:Demo01Interface.java
public class Demo01Interface{
public static void main(String[ ] args){
//创建实现类对象进行使用
MyInterfaceAbstractImpl impl = new MyInterfaceAbstractImpl();
impl.methodAbs1();
impl.methodAbs2();
}
}
//输出为:这是第1个方法
// 这是第2个方法
####java8新特性:
java8 开始 接口允许定义默认方法。
接口中的默认方法可以解决接口升级的问题。
格式:
public default 返回值类型 方法名 (参数列表){
方法体;
}
java8 开始 接口允许定义静态方法。
就是将abstract或者default换成static即可,带上方法体。
格式:
public static 返回值类型 方法名称(参数列表){
方法体;
}
使用的时候直接通过接口名称,直接调用其静态方法。
格式:接口名称.静态方法名(参数);
####java9新特性:
java9 开始 接口允许定义普通私有方法、静态私有方法。
普通私有方法:解决多个默认方法之间重复代码问题。
格式:
private 返回值类型 方法名称(){
方法体;
}
静态私有方法:解决多个静态方法之间重复代码问题。
格式:
private static 返回值类型 方法名称(参数列表){
方法体;
}
接口定义成员变量
接口中可以定义成员变量,但必须是public static final 三个关键字进行修饰。从效果上看就是接口的常量。
一旦使用final关键字进行修饰,说明不可改变。
注意事项:
1 接口当中的常量 可以省略public staticfinal 但是不建议这样。
2 接口中的常量 必须进行赋值 不能不符值。
3 接口中的常量名,使用完全大写的字幕 用下划线进行分割。
格式:
public static final 数据类型 常量名称 = 数据值;
例如:
public interface MyInterface{
public static final int num =10;
}
注意事项:
1 接口不能有静态代码块、构造方法。
2 一个类的直接弗雷是唯一的 但是可以一个类同时实现多个接口。
3 如果实现类所实现的多个接口当中存在重复的抽象方法,那么只需要覆盖重写一次即可。
4 如果实现类没有覆盖重写所有的抽象方法,那么实现类就必须是个抽象类。
5 如果实现类所实现的多个接口当中存在重复的默认方法,那么实现类一定要对冲突的方法进行覆盖重写。
6 一个类中 如果弗雷当中的方法和接口中的默认方法产生了冲突,会优先用父类中的方法。
接口与接口之间多继承关系
类与类之间是单继承,直接父类只有一个。
类与接口之间是多实现,一个类可以实现多个接口。
接口与接口之间是多继承。
多个父接口当中抽象方法如果重复没有关系。
多个父接口当中的默认方法如果重复,那么子接口必须进行默认方法的覆盖重写,而且带着default关键字。
####多态
extends继承或者implement实现 是多态的前提。
一个对象有多种形态,这就是对象的多态性。
代码中提现多态就是:弗雷引用只想子类对象。
格式:父类名称 对象名 = new 子类名称( );
或者: 接口名称 对象名称 = new 实现类名称( );
例子:
父类方法:
public class Fu{
public void method(){
System.out.println("父类方法");
}
}
子类方法:
public class Zi extends Fu {
@Override
public void menthod (){
System.out.println(" 子类方法 " );
}
}
实现类:
public class Demo01{
public static void main (String[ ] args){
//使用多态的方式 左侧父类的引用指向了右侧子类的引用对象。
Fu obj = new Zi( );
obj.method();
}
}
// 打印出来的是:子类方法。
成员变量:编译看左边 运行看左边。
成员方法:编译看左边 运行看右边。
对象的向上转型:
向上转型其实就是多态的一种写法,向上转型一定是安全的。但是一旦向上转型成为父类,那么就无法调用子类原本特有的功能。
格式:父类名称 对象名 = new 子类对象();
含义:右侧创建一个子类对象,把它当作父亲来看待使用。
对象的向下转型:
向下转型其实是一个还原的动作。
格式:子类名称 对象名 = (子类名称) 父类对象;
含义:将父类对象还原成本来的子类对象。
如何才能知道一个父类引用的对象 本来是什么子类?
用instanceof关键字进行判断。否则会出现异常。