Java8 Comparator原始碼演示及解析
阿新 • • 發佈:2020-01-07
在前面一篇Java Comparable和Comparator對比詳解中,對於java中的排序方法進行比較和具體剖析,主要是針對 Comparator介面和 Comparable介面,無論是哪種方式,都需要實現這個介面,並且重寫裡面的 方法。
Java8中對其進行了優化,直接呼叫Comparator類即可實現一些自定義的排序功能,比如按照某個欄位升序,並且按照某個欄位降序排列;還有如果出現null 的情況怎麼處理等等。下面是針對常見的 基礎資料型別的list 和 物件的集合 進行排序的演示。
/** * 關於 java8 中的 Comparator 排序方法 */ public class CompareController2 { public static void main(String[] args) { /** * 對常見的list等進行升序和降序 */ List<Integer> list = Arrays.asList(10,133,34,546,53,345); // 自然順序,升序 list.sort(Comparator.naturalOrder()); System.out.println(list); // 降序 list.sort(Comparator.reverseOrder()); System.out.println(list); /** * 對於 物件的排序 */ List<Students> studentsList = new ArrayList<>(); studentsList.add(new Students("zhangSan",28,"beiJing")); studentsList.add(new Students("liSi",25,"shangHai")); studentsList.add(new Students("wangWu",22)); studentsList.sort(Comparator.comparing(Students::getName)); System.out.println("按照姓名升序:" + studentsList); studentsList.sort(Comparator.comparing(Students::getAge).reversed()); System.out.println("按照年齡降序:" + studentsList); studentsList.sort(Comparator.comparing(Students::getAddress,Comparator.nullsLast(String::compareTo)).reversed()); System.out.println("按照地址降序,若有空,放到最前面:" + studentsList); studentsList.sort(Comparator.comparing(Students::getAddress,Comparator.nullsFirst(String::compareTo)).reversed()); System.out.println("按照地址降序,若有空,放到最後面:" + studentsList); studentsList.sort(Comparator.comparing(Students::getAddress,Comparator.nullsLast(String::compareTo)).reversed().thenComparing(Students::getAge)); System.out.println("按照地址降序,若有空,放到最前面,然後再按照年齡升序:" + studentsList); } }
Comparator的原始碼解析
最近的學習,讓我意識到了看原始碼的重要性,所以分析完Comparator如何使用後,繼續研究原始碼。
1)首先看下 comparing 的原始碼,其實就是 compareTo 方法。
2)接下看下 thenComparing 方法,其實就是 compare 方法,和我們實現某個介面並且重寫裡面的方法類似,只不過 Comparator在底層幫我們實現了。
3)最後來看下比較有趣的 nullsFirst 方法和 nullsLast 方法,兩個方法其實主要就是 nullFirst的標誌位不同,其底層仍然是 實現 compare方法,只不過加了一個對於null 的判斷,還有一個是根據 nullFirst的標誌位 的判斷。Get !!!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。