前言:终于有机会在工作中使用高版本的Java8,但是一直没有对java8中添加的新特性进一步了解过,所以趁着这个机会学习一下,能够在编程中熟练的使用。
一、接口的改变
我们知道,在java8版本以前,接口中只能定义静态常量和抽象方法,但是在java8添加了默认方法,也叫扩展方法;
public interface DefaultInterface {
//默认是public static final,也只能是
public static final int count=0;
//抽象方法
void add(); //默认方法==>扩展方法
default int add(int x,int y ) {
return x+y;
} }
这样,实现类不必实现默认方法,只需实现抽象方法,使用时直接调用接口中的方法。(好像和流式的api引入有关)
public class DefaultImpl implements DefaultInterface { @Override
public void add() {
System.out.println("我是抽象方法的实现"); }
public static void main(String[] args) {
DefaultInterface di=new DefaultImpl();
di.add();
di.add(12, 3);
}
}
还记得匿名内部类的使用吗?设计匿名内部类的目的就是方便程序员把代码作为数据传递。有时候写的多了会很烦这样的模板代码,但这还不是最重要的,最重要的是表达我们想传递的是行为,而不是对象。例如:
Collections.sort(list, new Comparator<String>() { public int compare(String o1, String o2) { return o1.compareTo(o2);
}
});
二、lamada表达式的引出
简写匿名内部类的模板代码:
(1)
Collections.sort(list,(String o1,String o2)->{
return o1.compareTo(o2);
});
(2)
Collections.sort(list,(String o1,String o2)->o1.compareTo(o2));
(3)
Collections.sort(list,(o1,o2)->o1.compareTo(o2));
方式(3)的参数类型是由编译器自行推导出的,根据上下文环境;但有时也要显示的声明。
2、你可还记得匿名内部类中只能使用final变量吗,但是在java8中放宽了这一限制,虽然不要求变量必须声明为final的,但是是即成事实上的final变量。
int num=0;
Collections.sort(list, new Comparator<String>() {
public int compare(String o1, String o2) {
System.out.println(num);;
return o1.compareTo(o2);
}
});
什么是即成事实上的final变量,虽然我们定义了num变量,但是在匿名内部类中仍不能对其做出修改,说明它是值。
同样我们如果在lamada表达式中对num做出修改,编译器会报“Local variable num defined in an enclosing scope must be final or effectively final”;
Collections.sort(list,(a,b)->num++);
3、lamada表达式的类型
我们知道在java中,所有的方法参数都有类型,那么lamada表达式的类型是什么?这里就要引出函数接口的概念:
什么是函数接口:就像前面提到的Comparable接口,接口只定义了一个抽象方法,public int compareTo(T o);其实Java中有很多这样的接口,我们把这样的接口称之为函数接口。只有这样的函数接口才能使用lamada表达式。
例如: 参数------------>函数接口------------->返回值类型