首页 > 编程语言 > 详细

Java8 sort方法

时间:2020-10-25 11:03:31      阅读:33      评论:0      收藏:0      [点我收藏+]

Sort方法

今天在使用sort方法的时候发现,不同的继承Collection接口的sort方法有不同的排序表达式

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(2);
arrayList.add(1);
arrayList.add(3);
arrayList.add(2);
arrayList.add(5);
arrayList.add(4);
arrayList.sort((o1, o2) -> o2 - o1); // 降序
arrayList.sort(Comparator.comparingInt(o -> o)) // 升序 当然也可以使用上面的lambda表达式:arrayList.sort((o1, o2) -> o1 - o2)
// 也可以使用Collection<T>接口的比较类
arrayList.sort(new Comparator<Integer>() {
    @Override
    public int compare(Integer o1, Integer o2) {
        return o1 - o2; // 升序,降序可类似上述方法
    }
});

也可以使用Collections工具类,只要是继承了Collection接口的类都可以使用这个方法来进行操作

// Collections类的构造方法是私有的,表示不能够被实例化
private Collections() {}
// Collections类的排序方法就直接使用Comparator类来做
Collections.sort(arrayList, new Comparator<Integer>() {
    @Override
    public int compare(Integer o1, Integer o2) {
        return o1 - o2;
    }
});

当然其他类都类似这样的操作

ArrayList<String> arrayList2 = new ArrayList<>();
arrayList2.add("abcd");
arrayList2.add("hbcd");
arrayList2.add("bbcd");
arrayList2.add("gbcd");
arrayList2.sort(String::compareTo); // 基本的升序排列
arrayList2.sort(Comparator.reverseOrder()); // 基本的降序排列
arrayList2.sort((o1, o2) -> o2.compareTo(o1)); // 可以这样使用降序排列
// 当然也可以使用Collections的sort工具方法,使用方式跟上述一致

Java8 sort方法

原文:https://www.cnblogs.com/Tchou/p/13871751.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!