Comparable與Comparator

Comparable

只有一個方法 
public int compareTo(T o);java

compareTo方法的返回值是int,有三種狀況:數組

一、比較者(調用compareTo方法者)大於被比較者(也就是compareTo方法接受對象),那麼返回 1dom

二、比較者等於被比較者,那麼返回0函數

三、比較者小於被比較者,那麼返回 -1測試

Comparable能夠認爲是一個內比較器,不少類都會實現這個接口以提供對該類對象之間比較的默認實現;好比String,Integer,Float,Double類都實現了Comparable接口。實現Comparable接口的類有一個特色,就是這些類提供了本身對象之間比較大小的默認實現,若是開發者add進入一個Collection的對象想要經過Collections的sort方法幫你自動進行排序的話,那麼這個add進入的對象類必須實現Comparable接口。this

package org.vincent.strategy.test;

/**
 * 實現一個類若是須要實現比較大小,那麼繼承Comparable接口,泛型參數T 是比較誰就寫誰
 * 
 * @ClassName: Domain
 * @Description: TODO(這裏用一句話描述這個類的做用)
 * @author PengRong
 * @date 2017年3月10日 下午6:41:54
 */
public class Domain implements Comparable<Domain> {

    private String string;

    public String getString() {
        return this.string;
    }

    public void setString(String string) {
        this.string = string;
    }

    public Domain(String name) {
        this.string = name;
    }

    public int compareTo(Domain o) {
        // TODO Auto-generated method stub
        if (this.string.compareTo(o.getString()) > 0)
            return 1;
        else if (this.string.compareTo(o.getString()) == 0)
            return 0;
        else
            return -1;
    }

}

測試代碼:spa

package org.vincent.strategy.test;

public class Test {
    public static void main(String[] args) {
        Domain d1 = new Domain("c");
        Domain d2 = new Domain("c");
        Domain d3 = new Domain("b");
        Domain d4 = new Domain("d");
        System.out.println(d1.compareTo(d2));
        System.out.println(d1.compareTo(d3));
        System.out.println(d1.compareTo(d4));
    }
}

輸出:code

0
1
-1

實現Comparable接口的類是爲了支持類對象之間是能夠比較的,可是其實代碼裏面Comparable的泛型未必就必定要是Domain,將泛型指定爲String或者指定爲其餘任何任何類型均可以—-只要咱們知道具體的比較類型就行。 
好比講Comparable的泛型參數指定爲String,相應compareTo函數變爲:對象

public int compareTo(String o) {
        // TODO Auto-generated method stub
        if (this.string.compareTo(o) > 0)
            return 1;
        else if (this.string.compareTo(o) == 0)
            return 0;
        else
            return -1;
    }

可是通常咱們不這樣作,泛型參數直接爲咱們定義的類Domain 
總結:Comparable接口就是用於給類提供默認比較功能的。排序

Comparator

Comparator能夠認爲是是一個外比較器,認爲有兩種狀況可使用實現Comparator接口的方式:

  • 一個對象不支持本身和本身比較(沒有實現Comparable接口),可是又想對兩個對象進行比較;通常同類型對象比較不多實現這個接口。

  • 一個對象實現了Comparable接口,可是開發者認爲compareTo方法中的比較方式並非本身想要的那種比較方式。Comparator接口更可能是實現這個功能。對特定比較需求提供支持。

int compare(T o1, T o2);

Comparator接口裏面有一個compare方法,方法有兩個參數T o1和T o2,是泛型的表示方式,分別表示待比較的兩個對象,方法返回值和Comparable接口同樣是int,有三種狀況:

  • 一、o1大於o2,返回1

  • 二、o1等於o2,返回0

  • 三、o1小於o3,返回-1

實例:

package org.vincent.strategy;

import java.util.Comparator;

/**
 * 定義一個按照絕對值排序的比較器
 *
 * @ClassName: AbsComparator
 * @Description: TODO(這裏用一句話描述這個類的做用)
 * @author PengRong
 * @date 2017年3月10日 下午6:06:41
 */
public class AbsComparator implements Comparator {
    public int compare(Object o1, Object o2) {
        int v1 = Math.abs(((Integer) o1).intValue());
        int v2 = Math.abs(((Integer) o2).intValue());
        return v1 > v2 ? 1 : (v1 == v2 ? 0 : -1);
    }
}

測試:

package org.vincent.strategy;

import java.util.Arrays;
import java.util.Random;

public class Test {
    @SuppressWarnings("unchecked")
    public static void main(String[] args) {

        // 產生一個20個隨機整數的數組(有正有負)
        Random rnd = new Random();
        Integer[] integers = new Integer[20];
        for (int i = 0; i < integers.length; i++) {
            integers[i] = new Integer(rnd.nextInt(100) * (rnd.nextBoolean() ? 1 : -1));
        }

        System.out.println("用Integer內置方法排序:也就是Integer實現Comparable接口所描述的比較方法");
        Arrays.sort(integers);
        System.out.println(Arrays.asList(integers));

        System.out.println("用AbsComparator排序:按絕對值大小排序");
        Arrays.sort(integers, new AbsComparator());
        System.out.println(Arrays.asList(integers));
    }
}

輸出結果:

用Integer內置方法排序:也就是Integer實現Comparable接口所描述的比較方法
[-88, -82, -82, -78, -70, -70, -58, -58, -48, -48, -46, -35, -10, 4, 7, 19, 39, 45, 53, 85]
用AbsComparator排序:按絕對值大小排序
[4, 7, -10, 19, -35, 39, 45, -46, -48, -48, 53, -58, -58, -70, -70, -78, -82, -82, 85, -88]
相關文章
相關標籤/搜索