【集合】comparable接口與comparator

作用:這兩個接口可以實現對類對象的集合進行排序

 

comparable接口:

一個類實現此接口,並實現其中的接口方法,那麼對這個類對象的集合進行排序時候,就可以把此comparable作爲默認的比較方法,進行自定義的升序或者降序集合排列;

 

現在情況出現改變,例如對於實現comparable的bean對象,其他地方可能需要按照此對象的另外幾個屬性信息進行排序,而不採用他默認的排序方式,但是對於此對象的默認比較方式(即對象實現了comparable的比較方法)又有另外一些地方需要使用,因此,在這樣一種背景下面,產生了comparator。

comparator   :

這個接口其實也就是一個自定義的比較算法,我們可以在對bean類定義自己的自定義的比較算法,可以根據實際的業務需求,加入實際需求的排序要求,例如按照年齡,或者地址等等

 

調用方式:

上面已經講了是對collection集合進行排序的,對於集合我們用的就是List和數組,同時我們也將了,對bean集合進行排序的時候可以使用默認的比較方式,也可以使用自定義的比較方式,因此寫法有下面兩種:

List類似的集合:Collections.sort(List<T> list);

指定自定義的比較方式:Collections.sort(List<T> list, Comparator<? super T> c)

 

數組集合的調用: Arrays.sort(T[] t); 

指定自定義的比較方式:Arrays. sort(T[] a, Comparator<? super T> c)

 

下面是代碼示例,可以自己測試:

 

定義bean對象,並創建自己默認的比較方法,即實現comparable接口:

 

public class PersonBean implements Comparable<PersonBean>{
	int age = 0;
	String name = "";
	
	public PersonBean(int age, String name) {
		this.age = age;
		this.name = name;
	}

	public int getAge() {
		return age;
	}

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

	public String getName() {
		return name;
	}

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

	public boolean equals(Object o) {
		if (!(o instanceof PersonBean)) {
			return false;
		}
		PersonBean p = (PersonBean) o;
		return (age == p.age) && (name.equals(p.name));
	}

	public int hashCode() {
		int result = 17;
		result = 31 * result + age;
		result = 31 * result + name.hashCode();
		return result;

	}

	public String toString() {
		return (age + "{" + name + "}");
	}


	public int compareTo(PersonBean person) {
		int cop = age - person.getAge();
		if (cop != 0)
			return cop;
		else
			return name.compareTo(person.name);
	}
}

 

 

 

 

自定義比較方式:

 

import java.util.Comparator;

public class AlphDesc implements Comparator<PersonBean> {

	
	public int compare(PersonBean personA, PersonBean personB) {
//		int cop = personA.age - personB.age;//按照年齡升序
		int cop = personB.age - personA.age;//按照年齡降序
		if (cop != 0)
			return cop;
		else
			return personB.getName().compareTo(personA.getName());

	}

	
}

 

public class TestComparable {
	@Test
	public void compare() {
		PersonBean[] p = { new PersonBean(10, "Tom"),
				new PersonBean(20, "Jeff"), 
				new PersonBean(30, "Mary"),
				new PersonBean(34, "Ada"), 
				new PersonBean(40, "Walton"),
				new PersonBean(61, "Peter"), 
				new PersonBean(80, "Bush") };
		System.out.println("before sort:\n" + Arrays.toString(p));
		AlphDesc desc = new AlphDesc();
		
		Arrays.sort(p);
		System.out.println("default Compare  after sort:\n" + Arrays.toString(p));
		
		Arrays.sort(p,desc);
		System.out.println("customer Compare  after sort:\n" + Arrays.toString(p));
	}

	
	@Test
	public void listCompare(){
		PersonBean[] p = { new PersonBean(10, "Tom"),
				new PersonBean(20, "Jeff"), 
				new PersonBean(30, "Mary"),
				new PersonBean(34, "Ada"), 
				new PersonBean(40, "Walton"),
				new PersonBean(61, "Peter"), 
				new PersonBean(80, "Bush") };
		
		List<PersonBean> list = Arrays.asList(p);
		System.out.println("before sort:\n" + Arrays.toString(p));
		System.out.println("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
		
		Collections.sort(list);
		System.out.println("default Compare  after sort:\n" + Arrays.toString(p));

		System.out.println("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");

		AlphDesc desc = new AlphDesc();
		Collections.sort(list,desc);
		System.out.println("customer Compare  after sort:\n" + Arrays.toString(p));

		
	}
	public static void main(String[] args) {
		TestComparable tc = new TestComparable();
		tc.compare();
	}
}

 

 

 

 

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章