淺析Java中comparator接口與Comparable接口的區(qū)別
Comparable 簡(jiǎn)介
Comparable 是排序接口。
若一個(gè)類實(shí)現(xiàn)了Comparable接口,就意味著“該類支持排序”。 即然實(shí)現(xiàn)Comparable接口的類支持排序,假設(shè)現(xiàn)在存在“實(shí)現(xiàn)Comparable接口的類的對(duì)象的List列表(或數(shù)組)”,則該List列表(或數(shù)組)可以通過 Collections.sort(或 Arrays.sort)進(jìn)行排序。
此外,“實(shí)現(xiàn)Comparable接口的類的對(duì)象”可以用作“有序映射(如TreeMap)”中的鍵或“有序集合(TreeSet)”中的元素,而不需要指定比較器。
1. Comparator 和 Comparable 相同的地方
他們都是java的一個(gè)接口, 并且是用來對(duì)自定義的class比較大小的,
什么是自定義class: 如 public class Person{ String name; int age }.
當(dāng)我們有這么一個(gè)personList,里面包含了person1, person2, persion3....., 我們用Collections.sort( personList ),
是得不到預(yù)期的結(jié)果的. 這時(shí)肯定有人要問, 那為什么可以排序一個(gè)字符串list呢:
如 StringList{"hello1" , "hello3" , "hello2"}, Collections.sort( stringList ) 能夠得到正確的排序, 那是因?yàn)?
String 這個(gè)對(duì)象已經(jīng)幫我們實(shí)現(xiàn)了 Comparable接口 , 所以我們的 Person 如果想排序, 也要實(shí)現(xiàn)一個(gè)比較器。
2. Comparator 和 Comparable 的區(qū)別
Comparable
Comparable 定義在 Person類的內(nèi)部:
public class Persion implements Comparable {..比較Person的大小..},
因?yàn)橐呀?jīng)實(shí)現(xiàn)了比較器,那么我們的Person現(xiàn)在是一個(gè)可以比較大小的對(duì)象了,它的比較功能和String完全一樣,可以隨時(shí)隨地的拿來
比較大小,因?yàn)镻erson現(xiàn)在自身就是有大小之分的。Collections.sort(personList)可以得到正確的結(jié)果。
Comparator
Comparator 是定義在Person的外部的, 此時(shí)我們的Person類的結(jié)構(gòu)不需要有任何變化,如
public class Person{ String name; int age },
然后我們另外定義一個(gè)比較器:
public PersonComparator implements Comparator() {..比較Person的大小..},
在PersonComparator里面實(shí)現(xiàn)了怎么比較兩個(gè)Person的大小. 所以,用這種方法,當(dāng)我們要對(duì)一個(gè) personList進(jìn)行排序的時(shí)候,
我們除了了要傳遞personList過去, 還需要把PersonComparator傳遞過去,因?yàn)樵趺幢容^Person的大小是在PersonComparator
里面實(shí)現(xiàn)的, 如:
Collections.sort( personList , new PersonComparator() ).
3. Comparator 和 Comparable 的實(shí)例
Comparable:
實(shí)現(xiàn)Comparable接口要覆蓋compareTo方法, 在compareTo方法里面實(shí)現(xiàn)比較:
public class Person implements Comparable { String name; int age; public int compareTo(Person another) { int i = 0; i = name.compareTo(another.name); // 使用字符串的比較 if(i == 0) { // 如果名字一樣,比較年齡, 返回比較年齡結(jié)果 return age - another.age; } else { return i; // 名字不一樣, 返回比較名字的結(jié)果. } } }
這時(shí)我們可以直接用 Collections.sort( personList ) 對(duì)其排序了.
Comparator:
實(shí)現(xiàn)Comparator需要覆蓋 compare 方法:
public class Person{ String name; int age; } class PersonComparator implements Comparator<Person> { public int compare(Person one, Person another) { int i = 0; i = one.name.compareTo(another.name); // 使用字符串的比較 if(i == 0) { // 如果名字一樣,比較年齡,返回比較年齡結(jié)果 return one.age - another.age; } else { return i; // 名字不一樣, 返回比較名字的結(jié)果. } } } Collections.sort( personList , new PersonComparator()) 可以對(duì)其排序
4:總結(jié)
兩種方法各有優(yōu)劣, 用Comparable 簡(jiǎn)單, 只要實(shí)現(xiàn)Comparable 接口的對(duì)象直接就成為一個(gè)可以比較的對(duì)象,
但是需要修改源代碼, 用Comparator 的好處是不需要修改源代碼, 而是另外實(shí)現(xiàn)一個(gè)比較器, 當(dāng)某個(gè)自定義
的對(duì)象需要作比較的時(shí)候,把比較器和對(duì)象一起傳遞過去就可以比大小了, 并且在Comparator 里面用戶可以自
己實(shí)現(xiàn)復(fù)雜的可以通用的邏輯,使其可以匹配一些比較簡(jiǎn)單的對(duì)象,那樣就可以節(jié)省很多重復(fù)勞動(dòng)了。
相關(guān)文章
spring boot 如何指定profile啟動(dòng)
這篇文章主要介紹了spring boot 如何指定profile啟動(dòng)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07基于Rest的API解決方案(jersey與swagger集成)
下面小編就為大家?guī)硪黄赗est的API解決方案(jersey與swagger集成)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08java拼接字符串時(shí)去掉最后一個(gè)多余逗號(hào)的方法
這篇文章主要介紹了java拼接字符串時(shí)去掉最后一個(gè)多余逗號(hào)的方法,實(shí)例分析了java操作字符串的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03