• Java8接口新特性


    概述

    Java 8中,你可以为接口添加静态方法默认方法。从技术角度来说,这是完全合法的,只是它看起来违反了接口作为一个抽象定义的理念。猜想设计初衷可能使为了兼容8以下的jdk Java8出来了个函数式接口,只要声明成函数式接口的接口都只能有一个抽象方法,为了便于扩展,赋予接口这么一个新特性
    静态方法:使用 static 关键字修饰。可以通过接口直接调用静态方法,并执行其方法体。我们经常在相互一起使用的类中使用静态方法。你可以在标准库中找到像Collection/Collections或者Path/Paths这样成对的接口和类。
    默认方法:默认方法使用 default 关键字修饰。可以通过实现类对象来调用。我们在已有的接口中提供新方法的同时,还保持了与旧版本代码的兼容性。
    比如:java 8 API中对Collection、List、Comparator等接口提供了丰富的默认方法。

    接口默认方法的类优先原则

    若一个接口中定义了一个默认方法,而另外一个父类或接口中又定义了一个同名的方法时
    选择父类中的方法。如果一个父类提供了具体的实现,那么接口中具有相同名称和参数的默认方法会被忽略。
    看例子:

    
    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();
    	}
    
    }
    
    
  • 相关阅读:
    并发编程之线程进阶
    并发编程之线程
    进程间通信(队列和管道)
    在python程序中的进程操作
    操作系统之进程
    网络编程之黏包
    树莓派 websocket 控制LED
    lua 调用 C -- 实例 C函数作为应用程序的一部分
    linux 环境下进程什么时候会被 killed掉
    STM32 + cJSON 死机问题解决
  • 原文地址:https://www.cnblogs.com/nnxud/p/9851183.html
Copyright © 2020-2023  润新知