您好,登錄后才能下訂單哦!
如何使用Java中的Compare和Comparator?相信很多新手小白對Compare和Comparator的了解處于懵懂狀態(tài),通過這篇文章的總結(jié),希望你能有所收獲。如下資料是關(guān)于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;
}
}
}
實現(xiàn)了Comparable接口的類需要實現(xiàn)compareTo()方法,傳入一個外部參數(shù)進行比對,實現(xiàn)了Comparator接口的方法需要實現(xiàn)compare()方法,對外部傳入的兩個類進行比較,從而讓外部方法在比較時調(diào)用。
兩者的區(qū)別是實現(xiàn)Comparator接口代碼更加靈活,可以定義某個類的多個比較器,從而在排序時根據(jù)實際場景自由調(diào)用,而Comparable接口實現(xiàn)后便不能改動。
總結(jié):
comparator接口:真正要實現(xiàn)的只有compare()方法,需要單獨準備出一個類來實現(xiàn)comparator接口,這個類將作為指定類的排序類
public int compare(Emp o1,Emp,o2){
return o1.id - o2.id
}
這是說如果o1的id - o2的id是正數(shù)就升序,如果負數(shù)降序。如果0就剔除
>0 升序
<0降序
=0 重復,不記錄
comparable接口
實現(xiàn)該類接口不需要重新創(chuàng)建一個排序的類,使用接口compareble接口排序,只要重寫里面的compareTo()方法
Collections類是一個包裝類,它包含有各種有關(guān)集合操作的靜態(tài)方法。就像一個工具類。
Collections.sort()
sort()排序方法,根據(jù)元素的自然排序?qū)χ付斜戆瓷蜻M行排序
public static <T>void sort(List<T> list,Comparator<>),根據(jù)指定比較器產(chǎn)生的順序?qū)χ付斜磉M行排序,此列表內(nèi)的所有元素都必須可使用指定的比較器相互比較
參數(shù):list——要排序的列表
C——確定列表順序的比較器
猜你還想看:
2、java如何重寫compareTo方法實現(xiàn)類排序
關(guān)于Java中的Compare和Comparator的使用方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果喜歡這篇文章,不如把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。