您好,登錄后才能下訂單哦!
如何使用Java中的Compare和Comparator?相信很多新手小白對Compare和Comparator的了解處于懵懂狀態,通過這篇文章的總結,希望你能有所收獲。如下資料是關于Compare和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;
else
return (o.price-this.price)>0?1:-1;
}
@Override
public 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就剔除
>0 升序
<0降序
=0 重復,不記錄
comparable接口
實現該類接口不需要重新創建一個排序的類,使用接口compareble接口排序,只要重寫里面的compareTo()方法
Collections類是一個包裝類,它包含有各種有關集合操作的靜態方法。就像一個工具類。
Collections.sort()
sort()排序方法,根據元素的自然排序對指定列表按升序進行排序
public static <T>void sort(List<T> list,Comparator<>),根據指定比較器產生的順序對指定列表進行排序,此列表內的所有元素都必須可使用指定的比較器相互比較
參數:list——要排序的列表
C——確定列表順序的比較器
猜你還想看:
關于Java中的Compare和Comparator的使用方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果喜歡這篇文章,不如把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。