1. 程式人生 > >淺談在java中list集合的排序問題

淺談在java中list集合的排序問題

定義實體類:

public class Person {
    private Integer  id;
    private  String  name;
    private  Integer  age;
    public Integer getId() {
        return id;
    }
    public void setId(Integer id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName
(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public Person(Integer id, String name, Integer age) { super(); this.id = id; this.name = name; this
.age = age; } public Person() { super(); // TODO Auto-generated constructor stub } @Override public String toString() { return "Person [id=" + id + ", name=" + name + ", age=" + age + "]"; } }

測試類Test:

public static void main(String[] args) {
    List
<Person> list=new ArrayList<Person>(50); list.add(new Person(1, "張三", 21)); list.add(new Person(2, "李四", 20)); list.add(new Person(3, "王五", 23)); list.add(new Person(4, "八戒", 22)); System.out.println(list);

這是會輸出對應的值
在java中所有的集合實現類都已經重寫toString()方法,不會輸出地址
問題:
1.根據編號從大到小排序
2.根據年齡從小到大排序
3.根據姓名排序(中文)
一、第一個問題:
編號問題,在java中有Collections.sort()方法
其中裡面的引數採用了過載

這裡寫圖片描述

其中第二個中的方法引數使用泛型中的下限(super)用法,把list放進去會報錯:報實體類Person的問題
其實sort()它要呼叫一個compareTo()方法
首先實現Comparable介面(加泛型Person)
這個時候實現方法

@Override
    public int compareTo(Person o) {
        // 根據id排序
        if(this.id>o.id) return -1;
        else if(this.id<o.id) return 1;
        return 0;
    }

這個時候會發現不會報錯,輸出即可

Person1 [id=4, name=八戒, age=22]
Person1 [id=3, name=王五, age=23]
Person1 [id=2, name=李四, age=20]
Person1 [id=1, name=張三, age=21]

二、第二個問題:
年齡問題,有人會說,把id裡面的值改一下就可以,但是如果還要比id呢??這種方法不可行,,這時候就可以使用
Collections.sort()中的過載
這裡寫圖片描述
這個時候我們就需要再寫一個寫AgeSort

public class AgeSort implements Comparator<Person1> {

    @Override
    public int compare(Person1 o1, Person1o2) {
        if(o1.getAge()>o2.getAge()) return 1;
        else if(o1.getAge()< o2.getAge()) return -1;
        return 0;
    }
}

直接在Test類中
Collections.sort(list, new AgeSort());輸出即可

Person1 [id=2, name=李四, age=20]
Person1 [id=1, name=張三, age=21]
Person1 [id=4, name=八戒, age=22]
Person1 [id=3, name=王五, age=23]

三、第三個問題:
姓名問題,再建立一個NameSort類

public class NameSort implements Comparator<Person1> {
    @Override
    public int compare(Person1 o1, Person1 o2) {
        return java.text.Collator.getInstance(Locale.CHINESE).compare(o1.getName(), o2.getName());
    }
}

再次輸出為:

Person1 [id=4, name=八戒, age=22]
Person1 [id=2, name=李四, age=20]
Person1 [id=3, name=王五, age=23]
Person1 [id=1, name=張三, age=21]

總結:
1.介面的好處:一個介面有多個實現類,在java中,當引數為介面時,一般都傳的是它對應的實現類
2.處理中文排序的問題,使用對應的java包java.text.Collator.getInstance(Locale.CHINESE)
java.text包還可以處理時間轉化問題等等(java.text.SimpleDateFormat)