Java8中接口的新特性使用指南

网友投稿 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小时内删除侵权内容。

上一篇:关于交换机之间捆绑路由的实验(交换机静态路由实验)
下一篇:路由基础之OSPFStub区域(在ospf路由域中)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~