淺談在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)

發佈了45 篇原創文章 · 獲贊 61 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章