閱讀484 返回首頁    go 阿裏雲 go 技術社區[雲棲]


Java中Comparable與Comparator的區別

一、概述
Comparable和Comparator都是用來實現集合中元素的比較、排序的。
Comparable是在集合內部定義的方法實現的排序,位於java.util下。
Comparator是在集合外部實現的排序,位於java.lang下。

Comparable是一個對象本身就已經支持自比較所需要實現的接口,如String、Integer自己就實現了Comparable接口,可完成比較大小操作。自定義類要在加入list容器中後能夠排序,也可以實現Comparable接口,在用Collections類的sort方法排序時若不指定Comparator,那就以自然順序排序。所謂自然順序就是實現Comparable接口設定的排序方式。


Comparator是一個專用的比較器,當這個對象不支持自比較或者自比較函數不能滿足要求時,可寫一個比較器來完成兩個對象之間大小的比較。Comparator體現了一種策略模式(strategy design pattern),就是不改變對象自身,而用一個策略對象(strategy object)來改變它的行為。

總而言之Comparable是自已完成比較,Comparator是外部程序實現比較。


二、例子
①Comparator的絕對值比較器


import java.util.Comparator;
public class AbsComparator<T> implements Comparator<T>
{
public int compare(Object o1, Object o2)
{
int ovalue1 = Math.abs(((Integer) o1).intValue());
int ovalue2 = Math.abs(((Integer) o2).intValue());
return (ovalue1 > ovalue2) ? 1 : (ovalue1 == ovalue2 ? 0 : -1);
}
}

import java.util.Arrays;
import java.util.Random;
public class AbsComparatorTest
{
public static void main(String[] args)
{
// 使用方法1
Random rn = new Random();
Integer[] integerArray = new Integer[20];
for (int i = 0; i < integerArray.length; i++)
{
integerArray[i] = new Integer(rn.nextInt(100) * (rn.nextBoolean() ? 1 : -1));
}
System.out.println("用Integer內置方法排序:");
Arrays.sort(integerArray);
System.out.println(Arrays.asList(integerArray));

System.out.println("用AbsComparator排序:");
Arrays.sort(integerArray, new AbsComparator<Integer>());
System.out.println(Arrays.asList(integerArray));

// 使用方法2
System.out.println("用AbsComparator比較-100和10的絕對值大小結果是:");
AbsComparator<Integer> absComparator = new AbsComparator<Integer>();
int result = absComparator.compare(new Integer(-100), new Integer(10));
System.out.println(result);
}
}

若不是調用sort方法,相要直接比較兩個對象的大小,Comparator定義了倆個方法,分別是int compare(T o1,T o2)和boolean equals(Object   obj)。有時在實現Comparator接口時,並沒有實現equals方法,可程序並沒有報錯,原因是實現該接口的類也是Object類的子類,而Object類已經實現了equals方法。


②comparable和comparator綜合例子
// 實現Comparable接口
public class Person implements Comparable<Object>
{
private int num;
private String name;
private int age;

public Person(int num, String name, int age)
{
super();
this.num = num;
this.name = name;
this.age = age;
}

public int compareTo(Object o)
{
return this.age - ((Person) o).getAge();
}

public int getNum()
{
return num;
}

public void setNum(int num)
{
this.num = num;
}

public String getName()
{
return name;
}

public void setName(String name)
{
this.name = name;
}

public int getAge()
{
return age;
}

public void setAge(int age)
{
this.age = age;
}
}

// 實現Comparator接口
import java.util.Comparator;
public class PersonComparator implements Comparator<Object>
{
@Override
public int compare(Object o1, Object o2)
{
int num1 = ((Person) o1).getNum();
int num2 = ((Person) o2).getNum();
return num1 > num2 ? 1 : (num1 == num2 ? 0 : -1);
}
}


// 測試
public class PersonTest
{
public static void main(String[] args)
{
Person p1 = new Person(1, "xy1", 22);
Person p2 = new Person(2, "xy1", 21);
System.out.println("實現Comparable接口方法結果(按年齡比較):"); // 結果為1
System.out.println(p1.compareTo(p2));

System.out.println("實現Comparator接口方法結果(按學號比較):"); // 結果為-1
PersonComparator pc = new PersonComparator();
System.out.println(pc.compare(p1, p2));

// 也可用聲明一個Person[] ps,通過Array.sort(ps)進行排序
}
}


原帖地址:https://ctzlylc.blog.163.com/blog/static/61967136201165981283/

最後更新:2017-04-03 12:55:57

  上一篇:go Android殺毒實現原理及實例
  下一篇:go IOS基礎 第二課