最近接了新的项目,jdk使用的是1.8+,但代码中完全没有用到java8的特性,于是着手精简了下代码,也抽空总结了一下给自己备忘。
先罗列一下我今天看到的一些相对与Java7的变化:
部分新特性
- 新增java.util.function包,包中都是使用注解@FunctionInterface修饰的接口,而这种接口就是所谓的函数式接口,一般使用这种接口作为参数的方法,就可以使用Lamb表达式作为值传入。
- 新增java.util.stream包,这个stream的概念和IO包中的流是完全不同的概念,这个Stream 是对集合(Collection)对象功能的增强,可以参考另一篇专门的文章传送门
- 接口中可以实现具体的方法了,当然还是和抽象类有区别的,接口中只能实现静态方法和default方法,这个据说是为了扩展集合相关接口想出来的方法,这个理解起来比较简单,可以参考这篇文章就可以了。
- 今天学到的重点:Comparator接口中新增了一系列的default方法,这些方法基本都返回一个Comparator实例,而这个实例就是用于列表的排序,方便的是,List接口本身实现了一个default的的sort方法,参数就是一个Comparator。
下面是一些简单的入门级别例子:
关于列表排序
List<Integer> list2 = Arrays.asList(1,2,3,4,5,6);
list2.sort((t1, t2) -> t2-t1); //重点
System.out.println(list2.stream().map((m) -> m.toString()).collect(Collectors.joining(",")));
这段代码中,第二行是重点,sort方法的参数是一个Comparator,这里使用一个Lamb表达式来实现了比较规则,这个可以分开来写,理解起来更简单一点。
List<Integer> list2 = Arrays.asList(1,2,3,4,5,6);
Comparator<Integer> comparator1 = (t1, t2) -> t2-t1;
list2.sort(comparator1);
//list2.sort(comparator1.reversed());
这样写更能明白整个过程,注释掉的第四行,意思是可以对上面那个Comparator对排序规则进行反转,这个reversed方法也是一个Comparator的default方法,很实用。
其实Comparator内置的一些default方法完全能实现简单排序规则
List<Integer> list2 = Arrays.asList(1,2,3,4,5,6);
Comparator<Integer> comparator1 = Comparator.comparingInt(Integer::intValue);
list2.sort(comparator1);
第二行的这种写法,就是使用Comparator中的default方法comparingInt来对整型的值进行排序。而双冒号的写法大概意思是动态调用其对象中的某个方法。我们写