java 比较器comparator_Java中比较器的使用Compare和Comparator
Comparable和Comparator接口都是為了對類進行比較,眾所周知,諸如Integer,double等基本數據類型,java可以對他們進行比較,而對于類的比較,需要人工定義比較用到的字段比較邏輯。可以把Comparable理解為內部比較器,而Comparator是外部比較器,基本的寫法如下:
class Apple implements Comparable{
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;
else
return (o.price-this.price)>0?1:-1;
}
@Override
public String toString() {
return "Apple{" +
"id=" + id +
", price=" + price +
'}';
}
}```
class AESComparator implements Comparator{
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就剔除
>0 升序
<0降序
=0 重復,不記錄
comparable接口
實現該類接口不需要重新創建一個排序的類,使用接口compareble接口排序,只要重寫里面的compareTo()方法
Collections類是一個包裝類,它包含有各種有關集合操作的靜態方法。就像一個工具類。
Collections.sort()
sort()排序方法,根據元素的自然排序對指定列表按升序進行排序
public static void sort(List list,Comparator<>),根據指定比較器產生的順序對指定列表進行排序,此列表內的所有元素都必須可使用指定的比較器相互比較
參數:list——要排序的列表
C——確定列表順序的比較器
總結
以上是生活随笔為你收集整理的java 比较器comparator_Java中比较器的使用Compare和Comparator的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux java内存分析_Java内
- 下一篇: java代码操作git_JGit--实现