lambda函数是变成对集合进行排序的几种方式

先来一个集合:
List<Point> points = 
Arrays.asList(
     new Point(1, 2),
     new Point(3, 2),
     new Point(4, 2),
     new Point(2, 2)
);
方式一:
// 比较器方法
Comparator<Point> byX = new Comparator<Point>() {
    @Override
    public int compare(Point p1, Point p2) {
          return Double.compare(p1.getX(), p2.getX());
    }
};
方式二(最简单):
Comparator<Point> byX = Comparator.comparing(Point::getX);
方式三(过时):
Comparator<Point> byX = (p1, p2) -> Double.compare(p1.getX(), p2.getX());
方式四:
Function<Point, Double> keyExtractor = point -> point.getX();
Comparator<Double> keyComparer = Double::compare;
Comparator<Point> byX = (p1, p2) -> keyComparer.compare(keyExtractor.apply(p1), keyExtractor.apply(p2));
方式五(方式四的进阶版推荐):
// 封装一个比较的方法
public static <T,U extends Comparable<U>> Comparator<T> comparing(Function<T,U> keyExtractor){
    return Comparator.comparing(keyExtractor::apply);
}

Function<Point, Double> keyExtractor = point -> point.getX();
Comparator<Point> byX = comparing(keyExtractor);
测试:
System.out.println("排序前:" + points);
points.sort(byX);
System.out.println("排序后:" + points);
测试结果:
排序前:
[java.awt.Point[x=1,y=2], 
 java.awt.Point[x=3,y=2], 
 java.awt.Point[x=4,y=2], 
 java.awt.Point[x=2,y=2]]
排序后:
[java.awt.Point[x=1,y=2], 
 java.awt.Point[x=2,y=2], 
 java.awt.Point[x=3,y=2], 
 java.awt.Point[x=4,y=2]]

本文参考:《精通lambda表达式:java多核编程》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值