轉自 http://blog.csdn.net/a1165117473/article/details/6965652
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package com.city.test;
import java.util.Arrays;
import java.util.Comparator;
/**
*
* @author LiuB
*/
public class sortTesty {
//對整數集合進行排序
public void sortIntArray() {
int[] array = new int[] { 8, 5, 9, 0, 6, 3, 4, 7, 2, 1 };
System.out.println("整數排序前");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + " ");
}
System.out.println();
Arrays.sort(array);
System.out.println("整數排序后");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + " ");
}
System.out.println();
}
//對字符串集合進行排序
public void sortStringArray() {
String[] array = new String[] { "a", "c", "e", "d", "b" };
System.out.println("字符串排序前");
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + " ");
}
System.out.println();
System.out.println("字符串排序后");
Arrays.sort(array);
for (int i = 0; i < array.length; i++) {
System.out.print(array[i] + " ");
}
System.out.println();
}
//對集合進行排序
java對集合排序的方法主要有兩種,分別為實現Comparator接口和實現Comparable接口。其中,實現Comparable接口比較簡單,用於單一標准的排序。如:
public class Animals implements Comparable<Animals>{
private String name;
public int age;
public Animals(String name, int age) {
this.name = name;
this.age = age;
}
public static void main(String[] args) {
LinkedList<Animals> list = new LinkedList<Animals>();
list.add(new Animals("a", 2));
list.add(new Animals("b", 4));
list.add(new Animals("c", 6));
Collections.sort(list);//需重寫compareTo()方法
for (Animals animals : list) {
System.out.println("Animals name=" + animals.name + "age="
+ animals.age);
}
}
@Override
public int compareTo(Animals o) {
if (this.age > o.age)
return 1;
if (this.age < o.age)
return -1;
else
return 0;
}
}
但如果要實現多種要求的排序,就要實現Comparator接口了。因為Comparable接口只能用一種方式比較。實現Comparator接口,如:
Collections.sort(list, new AnimalsComparator());//sort方法的兩個參數:比較的集合,比較器類的對象。
//比較器類,實現compare()方法
class AnimalsComparator implements Comparator<Animals> {
@Override
public int compare(Animals o1, Animals o2) {
if (o1.age > o2.age)
return 1;
if (o1.age < o2.age)
return -1;
else
return 0;
}
}
這樣,通過構建不同的比較器類,並在sort()方法里面傳入不同的比較器類對象,就能實現對象的不同屬性比較。上面是按年齡,如果按體重也可以,如:
Collections.sort(list, new AnimalsWeightComparator());
class AnimalsWeightComparator implements Comparator<Animals> {
@Override
public int compare(Animals o1, Animals o2) {
if (o1.weight> o2.weight)
return 1;
if (o1.weight< o2.weight)
return -1;
else
return 0;
}
}
當然PO類要有對應的屬性,並為屬性傳入參數。
