关于Java8新特性Lamb表达式简单了解

最近接了新的项目,jdk使用的是1.8+,但代码中完全没有用到java8的特性,于是着手精简了下代码,也抽空总结了一下给自己备忘。

先罗列一下我今天看到的一些相对与Java7的变化:

部分新特性
  1. 新增java.util.function包,包中都是使用注解@FunctionInterface修饰的接口,而这种接口就是所谓的函数式接口,一般使用这种接口作为参数的方法,就可以使用Lamb表达式作为值传入。
  2. 新增java.util.stream包,这个stream的概念和IO包中的流是完全不同的概念,这个Stream 是对集合(Collection)对象功能的增强,可以参考另一篇专门的文章传送门
  3. 接口中可以实现具体的方法了,当然还是和抽象类有区别的,接口中只能实现静态方法和default方法,这个据说是为了扩展集合相关接口想出来的方法,这个理解起来比较简单,可以参考这篇文章就可以了。
  4. 今天学到的重点: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来对整型的值进行排序。而双冒号的写法大概意思是动态调用其对象中的某个方法。我们写

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值