Java 8中,你能够为接口添加静态方法和默认方法。从技术角度来讲,这是彻底合法的,只是它看起来违反了接口做为一个抽象定义的理念。猜测设计初衷可能使为了兼容8如下的jdk Java8出来了个函数式接口,只要声明成函数式接口的接口都只能有一个抽象方法,为了便于扩展,赋予接口这么一个新特性
静态方法:使用 static 关键字修饰。能够经过接口直接调用静态方法,并执行其方法体。咱们常常在相互一块儿使用的类中使用静态方法。你能够在标准库中找到像Collection/Collections或者Path/Paths这样成对的接口和类。
默认方法:默认方法使用 default 关键字修饰。能够经过实现类对象来调用。咱们在已有的接口中提供新方法的同时,还保持了与旧版本代码的兼容性。
好比:java 8 API中对Collection、List、Comparator等接口提供了丰富的默认方法。java
若一个接口中定义了一个默认方法,而另一个父类或接口中又定义了一个同名的方法时
选择父类中的方法。若是一个父类提供了具体的实现,那么接口中具备相同名称和参数的默认方法会被忽略。
看例子:ide
package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午3:56:46 */ public interface Myfun { //新增了默认方法 有方法体了 default String getName() { return "return "接口中的getName方法"; } //还能够写静态方法 public static void show() { System.out.println("Java8接口中的静态方法"); } } package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午3:59:20 */ public class Myclass { public String getName() { return "类中的getName()方法"; } } package com.xnn.newInterface; /** * 类(接口)描述:既继承 又实现 遵循类优先原则 * @author xnn * 2018年10月25日下午4:00:29 */ public class MYsubClass extends Myclass implements Myfun { } package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午4:01:41 */ public class TEst { public static void main(String[] args) { MYsubClass class1 = new MYsubClass(); //调类里面的方法 System.out.println(class1.getName()); Myfun.show(); } }
结果函数
类中的getName()方法 Java8接口中的静态方法
若是一个父接口提供一个默认方法,而另外一个接口也提供了一个具备相同名称和参数列表的方法(无论方法是不是默认方法),那么实现类必须覆盖该方法来解决冲突
例子:设计
package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午3:56:46 */ public interface Myfun { //新增了默认方法 有方法体了 default String getName() { return "接口中的getName方法"; } //还能够写静态方法 public static void show() { System.out.println("Java8接口中的静态方法"); } } package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午4:03:45 */ public interface MyInterface { default String getName() { return "MYin接口" ; } } package com.xnn.newInterface; /** * 类(接口)描述: * @author xnn * 2018年10月25日下午3:59:20 */ public class Myclass { public String getName() { return "类中的getName()方法"; } } package com.xnn.newInterface; /** * 类(接口)描述:实现两个接口时 必须指定一个来解决冲突 * @author xnn * 2018年10月25日下午4:00:29 */ public class MYsubClass implements Myfun,MyInterface { @Override public String getName() { // TODO Auto-generated method stub return Myfun.super.getName(); } }