Java常用类(3)--Java比较器Comparable、Comparator类
文章目錄
- 自然排序:java.lang.Comparable
- 定制排序:java.util.Comparator
自然排序:java.lang.Comparable
Comparable接口強行對實現它的每個類的對象進行整體排序,這種排序被稱為類的自然排序。
實現 Comparable 的類必須實現 compareTo(Object obj) 方法,兩個對象即通過 compareTo(Object obj) 方法的返回值來比較大小。
實現Comparable接口的對象列表(和數組)可以通過 Collections.sort 或
Arrays.sort 進行自動排序。實現此接口的對象可以用作有序映射中的鍵或有序集合中的元素,無需指定比較器。
像String、包裝類等實現了Comparable接口,重寫了compareTo(obj o)方法,給出了比較兩個對象大小的方式。
像String、包裝類重寫compareTo()方法以后,默認可以進行從小到大的排列。
自定義類實現Comparable接口,重寫compareTo(obj)的規則:
如果當前對象this大于形參對象obj,則返回正整數 1
如果當前對象this小于形參對象obj,則返回負整數 -1
如果當前對象this等于形參對象obj,則返回零 0
示例:
import java.util.Arrays;class Good implements Comparable{private int price;private String name;public Good(String name,int price) {this.price = price;this.name = name;}@Override//先比較價格從低到高,再比較名稱按從大到小public int compareTo(Object o) {if (o instanceof Good){Good other = (Good) o;if (this.price > other.price) return 1;else if (this.price < other.price) return -1;else return -this.name.compareTo(other.name);}throw new RuntimeException("比較的不是Good!");}@Overridepublic String toString() {return "Good{" +"price=" + price +", name='" + name + '\'' +'}';} }public class ComparableTest {public static void main(String[] args) {Good[] goods = new Good[5];goods[0] = new Good("dell", 4668);goods[1] = new Good("ipad", 2628);goods[2] = new Good("dell", 688);goods[3] = new Good("huawei", 3229);goods[4] = new Good("xiaomi", 1688);Arrays.sort(goods);System.out.println(Arrays.toString(goods));} }Comparable 的典型實現類:(默認都是從小到大排列的)
①String:按照字符串中字符的Unicode值進行比較
②Character:按照字符的Unicode值來進行比較
③數值類型對應的包裝類以及BigInteger、BigDecimal:按照對應的數值大小進行比較
④Boolean:true 對應的包裝類實例大于 false 對應的包裝類實例
⑤Date、Time等:后面的日期時間比前面的日期時間大
定制排序:java.util.Comparator
當元素的類型沒有實現java.lang.Comparable接口而又不方便修改代碼,或者實現了java.lang.Comparable接口的排序規則不適合當前的操作,那么可以考慮使用 Comparator 的對象來排序,強行對多個對象進行整體排序的比較。
重寫compare(Object o1,Object o2)方法,比較o1和o2的大小:如果方法返回正整數,則表示o1大于o2;如果返回0,表示相等;返回負整數,表示o1小于o2。
可以將 Comparator 傳遞給 sort 方法(如 Collections.sort 或 Arrays.sort),從而允許在排序順序上實現精確控制。
還可以使用 Comparator 來控制某些數據結構(如有序 set或有序映射)的順序,或者為那些沒有自然順序的對象 collection 提供排序。
import java.util.Arrays; import java.util.Comparator;class Good {private int price;private String name;public Good(String name,int price) {this.price = price;this.name = name;}@Overridepublic String toString() {return "Good{" +"price=" + price +", name='" + name + '\'' +'}';}public int getPrice() {return price;}public String getName() {return name;} }public class ComparableTest {public static void main(String[] args) {Good[] goods = new Good[5];goods[0] = new Good("dell", 668);goods[1] = new Good("ipad", 928);goods[2] = new Good("dell", 928);goods[3] = new Good("huawei", 329);goods[4] = new Good("xiaomi", 168);Arrays.sort(goods,new Comparator(){@Override//先比較價格從低到高,再比較名稱按從大到小public int compare(Object o1, Object o2) {Good good1 = (Good) o1;Good good2 = (Good) o2;if (good1.getPrice() > good2.getPrice()) return 1;else if (good1.getPrice() < good2.getPrice()) return -1;else return good1.getName().compareTo(good2.getName());}});System.out.println(Arrays.toString(goods));} }總結
以上是生活随笔為你收集整理的Java常用类(3)--Java比较器Comparable、Comparator类的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: vivoy77手机参数(vivoy77手
- 下一篇: 怎么在电脑上改微信头像(如何在电脑上改微