关于Java8中的Comparator那些事

  在前面一篇博文中,对于java中的排序方法进行比较和具体剖析,主要是针对 Comparator接口和 Comparable接口,无论是哪种方式,都需要实现这个接口,并且重写里面的 方法。Java8中对其进行了优化,直接调用Comparator类即可实现一些自定义的排序功能,比如按照某个字段升序,并且按照某个字段降序排列;还有如果出现null 的情况怎么处理等等。下面是针对常见的 基础数据类型的list 和 对象的集合 进行排序的演示。

 1 /**
 2  * 关于 java8 中的 Comparator 排序方法
 3  */
 4 public class CompareController2 {
 5 
 6     public static void main(String[] args) {
 7 
 8         /**
 9          * 对常见的list等进行升序和降序
10          */
11         List<Integer> list = Arrays.asList(10,133,34,546,53,345);
12         // 自然顺序,升序
13         list.sort(Comparator.naturalOrder());
14         System.out.println(list);
15         // 降序
16         list.sort(Comparator.reverseOrder());
17         System.out.println(list);
18 
19         /**
20          * 对于 对象的排序
21          */
22         List<Students> studentsList = new ArrayList<>();
23         studentsList.add(new Students("zhangSan", 28, "beiJing"));
24         studentsList.add(new Students("liSi", 25, "shangHai"));
25         studentsList.add(new Students("wangWu", 22));
26 
27         studentsList.sort(Comparator.comparing(Students::getName));
28         System.out.println("按照姓名升序:" + studentsList);
29 
30         studentsList.sort(Comparator.comparing(Students::getAge).reversed());
31         System.out.println("按照年龄降序:" + studentsList);
32 
33         studentsList.sort(Comparator.comparing(Students::getAddress, Comparator.nullsLast(String::compareTo)).reversed());
34         System.out.println("按照地址降序,若有空,放到最前面:" + studentsList);
35 
36         studentsList.sort(Comparator.comparing(Students::getAddress, Comparator.nullsFirst(String::compareTo)).reversed());
37         System.out.println("按照地址降序,若有空,放到最后面:" + studentsList);
38 
39         studentsList.sort(Comparator.comparing(Students::getAddress, Comparator.nullsLast(String::compareTo)).reversed().thenComparing(Students::getAge));
40         System.out.println("按照地址降序,若有空,放到最前面,然后再按照年龄升序:" + studentsList);
41 
42     }
43 }

Comparator的源码解析

最近的学习,让我意识到了看源码的重要性,所以分析完Comparator如何使用后,继续研究源码。

  1)首先看下 comparing 的源码,其实就是 compareTo 方法。

       

  2)接下看下 thenComparing 方法,其实就是 compare 方法,和我们实现某个接口并且重写里面的方法类似,只不过 Comparator在底层帮我们实现了。

       

  3)最后来看下比较有趣的 nullsFirst 方法和 nullsLast 方法,两个方法其实主要就是 nullFirst的标志位不同,其底层仍然是 实现 compare方法,只不过加了一个对于null 的判断,还有一个是根据 nullFirst的标志位 的判断。Get !!!

     

     

原文地址:https://www.cnblogs.com/Demrystv/p/11564269.html