Java中的比较器
Comparable和Comparator接口都是為了對(duì)類進(jìn)行比較,眾所周知,諸如Integer,double等基本數(shù)據(jù)類型,java可以對(duì)他們進(jìn)行比較,而對(duì)于類的比較,需要人工定義比較用到的字段比較邏輯。可以把Comparable理解為內(nèi)部比較器,而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;}} }實(shí)現(xiàn)了Comparable接口的類需要實(shí)現(xiàn)compareTo()方法,傳入一個(gè)外部參數(shù)進(jìn)行比對(duì),實(shí)現(xiàn)了Comparator接口的方法需要實(shí)現(xiàn)compare()方法,對(duì)外部傳入的兩個(gè)類進(jìn)行比較,從而讓外部方法在比較時(shí)調(diào)用。
兩者的區(qū)別是實(shí)現(xiàn)Comparator接口代碼更加靈活,可以定義某個(gè)類的多個(gè)比較器,從而在排序時(shí)根據(jù)實(shí)際場(chǎng)景自由調(diào)用,而Comparable接口實(shí)現(xiàn)后便不能改動(dòng)。
?總結(jié):
comparator接口:真正要實(shí)現(xiàn)的只有compare()方法,需要單獨(dú)準(zhǔn)備出一個(gè)類來(lái)實(shí)現(xiàn)comparator接口,這個(gè)類將作為指定類的排序類
public int compare(Emp o1,Emp,o2){return o1.id - o2.id } 這是說(shuō)如果o1的id - o2的id是正數(shù)就升序,如果負(fù)數(shù)降序。如果0就剔除 >=1 升序 <=-1 降序 =0 重復(fù),不記錄comparable接口
實(shí)現(xiàn)該類接口不需要重新創(chuàng)建一個(gè)排序的類,使用接口compareble接口排序,只要重寫里面的compareTo()方法
?
Collections類是一個(gè)包裝類,它包含有各種有關(guān)集合操作的靜態(tài)方法。就像一個(gè)工具類。
Collections.sort()
sort()排序方法,根據(jù)元素的自然排序?qū)χ付斜戆瓷蜻M(jìn)行排序
public static <T>void sort(List<T> list,Comparator<>),根據(jù)指定比較器產(chǎn)生的順序?qū)χ付斜磉M(jìn)行排序,此列表內(nèi)的所有元素都必須可使用指定的比較器相互比較
參數(shù):list——要排序的列表
????????? C——確定列表順序的比較器
總結(jié)
- 上一篇: Redis.conf常见配置介绍
- 下一篇: Java 8系列之重新认识HashMap