为什么枚举要实现接口?
343
2022-09-18
Java8中接口的新特性使用指南
目录前言编写测试类ComepareTest第一种情况,一个类实现了接口的同时又继承了一个父类情况二情况三总结
前言
在java8中接口中不再只有抽象方法,还可以有静态方法以及默认方法,此时的接口更像是一个类。我们一起来看看如何使用吧~
Java8中,可以为接口添加静态方法和默认方法。
静态方法:使用static关键字修饰。可以通过接口直接调用静态方法,并执行其方法体
默认方法:使用default关键字修饰。可以通过类来调用
直接看代码吧
package com.nanfeng.demo.interfacepractice.java8;
/**
* java8中的新特性
* 在接口中默认方法的权限是public,所以public也可以省略
*/
public interface CompareA {
// 接口中可以定义抽象方法
public static void method1() {
System.out.println("Java8中接口中可以定义静态方法,通过接口来调用--1");
}
// 默认方法
public default void method2() {
System.out.println("Java8中接口中可以定义默认方法--2");
}
public default void method3() {
System.out.println("Java8中接口中可以定义默认方法--3");
}
}
编写测试类ComepareTest
package com.nanfeng.demo.interfacepractice.java8;
public class CompareATest {
public static void main(String[] args) {
// 创建实现类对象
CompareAClass c = new CompareAClass();
/**
* 知识点一:接口中的静态方法 只能通过接口来调用
* Static method may be invoked on containing interface class only
* 静态方法只能在包含接口类时调用 */
// c.method1();
// 使用接口调用method1()方法,此时的接口有点像工具类了
CompareA.method1();
/**
* 知识点二:
* 默认方法,可以通过创建实现类的对象来调用接口中的默认方法
* 或者也可以对接口中的默认方法进行重写
*/
c.method2();
}
}
class CompareAClass implements CompareA {
/**
* 在实现类中对接口中的默认方法进行重写时
* 注意:不可以省略public权限修饰,否则会报错
* 执行时,依然会调用我们重写后的方法,符合继承
*
*
*/
@Override
public void method2() {
System.out.println("Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略");
}
}
运行结果:
Java8中接口中可以定义静态方法,通过接口来调用
Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略--2
第一种情况,一个类实现了接口的同时又继承了一个父类
1、创建实现类的父类
package com.nanfeng.demo.interfacepractice.java8;
/**
* 实现类的父类
*/
public class SuperClass {
// 定义与接口中同名的方法
public void method3(){
System.out.println("实现类的父类中,出现和接口中同名同参数的方法--SuperClass");
}
}
2、让子类实现接口的同时继承父类
package com.nanfeng.demo.interfacepractice.java8;
public class CompareATest {
public static void main(String[] args) {
// 创建实现类对象
Compahttp://reAClass c = new CompareAClass();
/**
* 知识点一:接口中的静态方法 只能通过接口来调用
* Static method may be invoked on containing interface class only
* 静态方法只能在包含接口类时调用 */
// c.method1();
// 使用接口调用method1()方法,此时的接口有点像工具类了
CompareA.method1();
/**
* 知识点二:
* 默认方法,可以通过创建实现类的对象来调用接口中的默认方法
* 或者也可以对接口中的默认方法进行重写
*/
c.method2();
/**
* 知识点三:
* 父类中的方法和接口中的方法同名时应该怎么处理?
* 如果子类(或实现类)继承的父类和实现的接口中声明了同名同参的方法
* 那么在子类没有重写此方法时,默认的调用的是父类中同名同参的方法。
* -->类优先原则
*/
c.method3();
}
}
class ComepareAClass extends SuperClass implements CompareA {
/**
* 在实现类中对接口中的默认方法进行重写时
* 注意:不可以省略public权限修饰,否则会报错
* 执行时,依然会调用我们重写后的方法,符合继承
*/
@Override
public void method2() {
System.out.println("Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略");
}
}
运行查看结果:
Java8中接口中可以定义静态方法,通过接口来调用--1
Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略--2
实现类的父类中,出现和接口中同名的方法--SuperClass
情况二
实现类在没有继承父类的前提下,对多个接口进行实现,应该如何处理
1、创建CompareB接口,创建和CompareA接口中通同参的默认方法
注意:如果一个类同时继承多个接口,接口中出现同名同参的默认方法时,会出现接口冲突。此时,实现类必须重写此方法
/**
* Java接口中支持接口的多继承
* 情况一:
* class ComepareAClass extends SuperClass implements CompareA
* CompareA接口和SuperClass父类出现同名同参的方法时,默认会调用父类中的方法,体现了类优先原则
* 情况二:
* class ComepareAClass implements CompareA, CompareB
* 在没有继承父类的前提下,一个类对多个接口继承的前提下,两个接口中定义了同名同参的默认方法,会如何执行?
* 知识点四:
* 如果一个实现类实现了多个接口,而这多个接口中定义了同名同参的默认方法,那么在实现类没有重写此方法的情况下,报错
* -->会出现借口冲突
* 这就必须我们在实现类中重写此方法
*
*/
class CompareAClass implements CompareA, CompareB {
/**
* 在实现类中对接口中的默认方法进行重写时
* 注意:不可以省略public权限修饰,否则会报错
* 执行时,依然会调用我们重写后的方法,符合继承
*/
@Override
public void method2() {
System.out.println("Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略--2");
}
// 解决接口冲突,必须对接口中的方法进行重写
@Override
public void method3() {
System.out.println("ComepareAClass实现类对多个接口中的同名方法进行重写,重写后执行的就是实现类中的方法--method3()");
}
}
运行结果:
Java8中接口中可以定义静态方法,通过接口来调用--1
Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略--2
ComepareAClass实现类对多个接口中的同名方法进行重写,重写后执行的就是实现类中的方法--method3()
情况三
在子类(或实现类)中自己定义的方法中,调用接口和父类中没有被重写的方法
/**
* Java接口中支持接口的多继承
nMPJpN* 情况一:
* class ComepareAClass extends SuperClass implements CompareA
* CompareA接口和SuperClass父类出现同名同参的方法时,默认会调用父类中的方法,体现了类优先原则
* 情况二:
* class ComepareAClass implements CompareA, CompareB
* 在没有继承父类的前提下,一个类对多个接口继承的前提下,两个接口中定义了同名同参的默认方法,会如何执行?
* 知识点四:
* 如果一个实现类实现了多个接口,而这多个接口中定义了同名同参的默认方法,那么在实现类没有重写此方法的情况下,报错
* -->会出现借口冲突
* 这就必须我们在实现类中重写此方法
* 情况三:
* class CompareAClass extends SuperClass implements CompareA, CompareB
* 一个子类(或实现类)继承父类的同时实现多个接口
* 在子类(或实现类)中自己定义的方法中,调用接口和父类中没有被重写的方法
* */
class CompareAClass extends SuperClass implements CompareA, CompareB {
/**
* 在实现类中对接口中的默认方法进行重写时
* 注意:不可以省略public权限修饰,否则会报错
* 执行时,依然会调用我们重写后的方法,符合继承
*/
@Override
public void method2() {
System.out.println("Java8中实现类可以对接口中的默认方法进行重写,注意声明方法的权限修饰符为public,且public不可省略--2");
}
// 解决接口冲突,必须对接口中的方法进行重写
@Override
public void method3() {
System.out.println("ComepareAClass实现类对多个接口中的同名方法进行重写,重写后执行的就是实现类中的方法--method3()");
}
/**
* 知识点五:如何在子类(或实现类)的方法中调用父类(或者接口中)没有被重写的方法
*/
public void myMethod(){
// 调用自己重写的method3()方法
this.method3();
// 调用父类中声明的method3()方法
super.method3();
// 调接口中的默认方法(注意:是非静态方法,所以不可以使用接口名调用)
//调用方式:接口名.super.方法
CompareA.super.method3();
CompareB.super.method3();
}
}
总结
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~