Java中的比较器
Comparable和Comparator接口都是為了對類進行比較,眾所周知,諸如Integer,double等基本數據類型,java可以對他們進行比較,而對于類的比較,需要人工定義比較用到的字段比較邏輯??梢园袰omparable理解為內部比較器,而Comparator是外部比較器,基本的寫法如下:
class Apple implements Comparable<Apple>{int id;double price;public Apple(int id, double price) {this.id = id;this.price = price;}public int compareTo(Apple o) {//return Double.compare(this.getPrice(),o.getPrice());if (Math.abs(this.price-o.price)<0.001)return 0;elsereturn (o.price-this.price)>0?1:-1;}@Overridepublic String toString() {return "Apple{" +"id=" + id +", price=" + price +'}';} } class AESComparator implements Comparator<Apple>{public int compare(Apple o1, Apple o2) {if (Math.abs(o1.price-o2.price)<0.001)return 0;else{return (o1.price-o2.price)>0?1:-1;}} }實現了Comparable接口的類需要實現compareTo()方法,傳入一個外部參數進行比對,實現了Comparator接口的方法需要實現compare()方法,對外部傳入的兩個類進行比較,從而讓外部方法在比較時調用。
兩者的區別是實現Comparator接口代碼更加靈活,可以定義某個類的多個比較器,從而在排序時根據實際場景自由調用,而Comparable接口實現后便不能改動。
?總結:
comparator接口:真正要實現的只有compare()方法,需要單獨準備出一個類來實現comparator接口,這個類將作為指定類的排序類
public int compare(Emp o1,Emp,o2){return o1.id - o2.id } 這是說如果o1的id - o2的id是正數就升序,如果負數降序。如果0就剔除 >=1 升序 <=-1 降序 =0 重復,不記錄comparable接口
實現該類接口不需要重新創建一個排序的類,使用接口compareble接口排序,只要重寫里面的compareTo()方法
?
Collections類是一個包裝類,它包含有各種有關集合操作的靜態方法。就像一個工具類。
Collections.sort()
sort()排序方法,根據元素的自然排序對指定列表按升序進行排序
public static <T>void sort(List<T> list,Comparator<>),根據指定比較器產生的順序對指定列表進行排序,此列表內的所有元素都必須可使用指定的比較器相互比較
參數:list——要排序的列表
????????? C——確定列表順序的比較器
總結
- 上一篇: Redis.conf常见配置介绍
- 下一篇: Java 8系列之重新认识HashMap