Java中比較器Comparator和Comparable的區(qū)別
一、背景
我們?cè)谑褂?Collections.sort()
對(duì)鏈表進(jìn)行排序(或者使用 Arrays.sort()
對(duì)數(shù)組進(jìn)行排序)時(shí),常常需要根據(jù)不同情況自定義排序規(guī)則。
比如:當(dāng)我們存儲(chǔ)學(xué)生對(duì)象時(shí),我們需要按照學(xué)生年齡進(jìn)行排序,這時(shí)我們就可以通過比較器 Comparator 或者 Comparable 對(duì)排序順序進(jìn)行控制。
本文將結(jié)合示例對(duì) Comparator 和 Comparable 兩種比較器的使用進(jìn)行介紹
二、Comparable
Comparable 是一個(gè)接口,其本質(zhì)上是一個(gè)內(nèi)比較器(在類內(nèi)部)。
需要定義排序/比較規(guī)則的類實(shí)現(xiàn) Comparable 接口,并且重寫 compareTo(Object o)
方法,從而自定義比較規(guī)則。
public interface Comparable<T>
Comparable 代碼示例 :
下面的代碼為 Student
類重寫了 compareTo
方法,實(shí)現(xiàn)了 Student 對(duì)象按照 age 大小進(jìn)行比較
public class Student implements Comparable<Object> { String name; int age; public Student(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "{" + this.getName() + "," + this.getAge() + "}"; } // 通過重寫 compareTo 方法,實(shí)現(xiàn)比較器 @Override public int compareTo(Object o) { Student student = (Student) o; return this.age - student.getAge(); } public static void main(String[] args) { List<Student> list = new ArrayList<>(); list.add(new Student("wanqing", 21)); list.add(new Student("xinyu", 23)); list.add(new Student("huahua", 1)); Collections.sort(list); System.out.println(list); } }
可以觀察到輸出結(jié)果按照 age 升序進(jìn)行了排序 ——
三、Comparator
Comparator
是一個(gè)外比較器,其使用場(chǎng)景為當(dāng)一個(gè)類未實(shí)現(xiàn) Comparable 方法,或者實(shí)現(xiàn)的 Comparable 方法的比較規(guī)則不是我們現(xiàn)在想用的(比如我們想按照降序的方式排序),我們就可以通過為 sort()
方法傳入 Comparator
的形式,自定義排序規(guī)則。
其使用方式如下:
Collections.sort(List<T> list, Comparator<? super T> c); Arrays.sort(T[] a, Comparator<? super T> c);
Comparator
重寫 compare
方法,方法內(nèi)部重寫比較規(guī)則
Comparator 代碼示例
下面代碼通過傳入 Comparator比較器 的方式,實(shí)現(xiàn)了對(duì) list 按照學(xué)生年齡降序排序
public static void main(String[] args) { List<Student> list = new ArrayList<>(); list.add(new Student("wanqing", 21)); list.add(new Student("xinyu", 23)); list.add(new Student("huahua", 1)); // 實(shí)現(xiàn)對(duì) list 按照學(xué)生年齡降序排序 Collections.sort(list, new Comparator<Student>() { @Override public int compare(Student o1, Student o2) { // 降序排序 return o2.getAge() - o1.getAge(); } }); System.out.println(list); }
可以觀察到輸出結(jié)果按照 age 進(jìn)行了降序排序 ——
到此這篇關(guān)于Java中比較器Comparator和Comparable的區(qū)別的文章就介紹到這了,更多相關(guān)Java的Comparator和Comparable內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Netty分布式pipeline管道Handler的添加代碼跟蹤解析
這篇文章主要介紹了Netty分布式pipeline管道Handler的添加代碼跟蹤解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03Java使用正則表達(dá)式截取重復(fù)出現(xiàn)的XML字符串功能示例
這篇文章主要介紹了Java使用正則表達(dá)式截取重復(fù)出現(xiàn)的XML字符串功能,涉及java針對(duì)xml字符串及指定格式字符串的正則匹配相關(guān)操作技巧,需要的朋友可以參考下2017-08-08Java如何使用JSR303校驗(yàn)數(shù)據(jù)與自定義校驗(yàn)注解
這篇文章主要介紹了Java如何使用JSR303校驗(yàn)數(shù)據(jù)與自定義校驗(yàn)注解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09解決@DateTimeFormat格式化時(shí)間出錯(cuò)問題
這篇文章主要介紹了解決@DateTimeFormat格式化時(shí)間出錯(cuò)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12J2EE Servlet基礎(chǔ)在瀏覽器上運(yùn)行HelloServlet的方法
這篇文章主要介紹了J2EE Servlet基礎(chǔ)在瀏覽器上運(yùn)行HelloServlet的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10SpringMvc接受請(qǐng)求參數(shù)的幾種情況演示
Springmvc接受請(qǐng)求參數(shù)的幾種介紹,如何接受json請(qǐng)求參數(shù),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-07-07java實(shí)現(xiàn)Object轉(zhuǎn)String的4種方法小結(jié)
這篇文章主要介紹了java實(shí)現(xiàn)Object轉(zhuǎn)String的4種方法小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09SpringBoot集成內(nèi)存數(shù)據(jù)庫Sqlite的實(shí)踐
sqlite這樣的內(nèi)存數(shù)據(jù)庫,小巧可愛,做小型服務(wù)端演示程序,非常好用,本文主要介紹了SpringBoot集成Sqlite,具有一定的參考價(jià)值,感興趣的可以了解一下2021-09-09