怎么進(jìn)行Java Comparable和Comparator的對(duì)比,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信平臺(tái)小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了渦陽免費(fèi)建站歡迎大家使用!
在實(shí)際項(xiàng)目開發(fā)過程中,我們經(jīng)常需要對(duì)某個(gè)對(duì)象或者某個(gè)集合中的元素進(jìn)行排序,常用的兩種方式是實(shí)現(xiàn)某個(gè)接口。常見的可以實(shí)現(xiàn)比較功能的接口有Comparable接口和 Comparator接口,那么這兩個(gè)又有什么區(qū)別呢?
關(guān)于Comparable接口
關(guān)于Comparable接口,其位于 java.lang.Comparable 中,實(shí)現(xiàn)這個(gè)接口,可以通過重寫其 compareTo 方法進(jìn)行自定義排序,一般用于實(shí)體類中,比如針對(duì)學(xué)生對(duì)象,根據(jù)其姓名、身高、年齡、地址等進(jìn)行排序,商品根據(jù)名稱、庫存、價(jià)格排序等。下面一段代碼中主要是對(duì) 學(xué)生的姓名、年齡、地址進(jìn)行排序,當(dāng)我們重寫其 compareTo 方法后,對(duì)于一個(gè)學(xué)生對(duì)象的集合,我們可以通過調(diào)用 Collections.sort(studentList) 對(duì)其進(jìn)行排序,即可達(dá)到想要的效果。
public class Students implements Comparable
關(guān)于Comparator接口
關(guān)于Comparator接口,其位于 java.util.Comparator 中,實(shí)現(xiàn)這個(gè)接口,可以通過重寫其 compare 方法進(jìn)行自定義的排序,比如針對(duì) 字符串的 list,根據(jù)其長度遞減排序;根據(jù)Integer 的集合,根據(jù)其大小升序(Collections.sort()方法中默認(rèn)實(shí)現(xiàn)的就是升序)。此外,針對(duì)數(shù)組的排序,還可以調(diào)用 Arrays.sort() 進(jìn)行排序,其默認(rèn)是根據(jù)字典順序進(jìn)行排序。
import java.util.*;public class CompareController1 implements Comparator
擴(kuò)展補(bǔ)充:
關(guān)于Collections.sort()和 Arrays.sort()
1) Collections.sort()方法底層實(shí)際就是Arrays.sort(),
2) Arrays.sort()的底層分為兩種,滿足某種條件就調(diào)用這個(gè)排序 legacyMergeSort,其底層就是歸并排序;如果不滿足,就是 TimSort
3) TimSort 的底層根據(jù)數(shù)組的長度進(jìn)行區(qū)分,如果數(shù)組的長度小于32,直接使用簡單的合并算法,即二分插入排序(binary merge sort);如果長度大于32,就是 合并算法。
看完上述內(nèi)容,你們掌握怎么進(jìn)行Java Comparable和Comparator的對(duì)比的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!