對List集合中的對象進行按某個屬性排序


最近在實際的開發工作中,碰到排序的問題,如題,我們如何針對List集合中的某一個屬性進行排序

參考:https://blog.csdn.net/qq_39366175/article/details/79449178

這里先舉一個簡單的例子:

復制代碼
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * Created by IntelliJ IDEA
 * 這是一個神奇的Class
 *
 * @author zhz
 * @date 2019/9/25 10:37
 */
public class DemoTest {
    public static void main(String[] args) {


        List<String> list1 = new ArrayList<>();
        list1.add("3");
        list1.add("4");
        list1.add("1");
        list1.add("2");
        list1.add("f");
        list1.add("a");
        System.out.println("排序前--:"+list1.toString());
        Collections.sort(list1);
        System.out.println("排序前后--:"+list1.toString());


    }
}
復制代碼

打印結果如下:

 

 可以總結為,加單的String類型的排序,是排數字,再排字母,默認排序方式是升序。

下面言歸正傳,要是一個List中存的是某種對象,該對象有多種屬性,那么如何進行升序或者降序排序呢?

這個時候我們就會進行一系列猛如虎的操作,結果有可能會遇到下面這種坑:

 

 這時候你可能會問那我們怎么搞啊:

下面首先我們先創建一個測試用類,這里重點說一哈,可以實現一個Comparable接口重寫compareTo

復制代碼
/**
 * Created by IntelliJ IDEA
 * 這是一個神奇的Class
 *
 * @author zhz
 * @date 2019/9/25 10:49
 */
public class TestA implements Comparable<TestA> {
    private String name;

    private Integer age;

    public TestA(String name, Integer age) {
        super();
        this.name = name;
        this.age = age;
    }

    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;
    }

    @Override
    public String toString() {
        return "TestA [name=" + name + ", age=" + age + "]";
    }

    @Override
    public int compareTo(TestA o) {
        return this.age.compareTo(o.getAge());
    }
    
}
復制代碼

我們就可以進行下一步的檢驗結果的操作了

復制代碼
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/**
 * Created by IntelliJ IDEA
 * 這是一個神奇的Class
 *
 * @author zhz
 * @date 2019/9/25 10:37
 */
public class DemoTest {
    
    public static void main(String[] args) {

        TestA testA1 = new TestA("老張", 3);
        TestA testA2 = new TestA("老李", 1);
        TestA testA3 = new TestA("老王", 2);
        List<TestA> list  = new ArrayList<>();
        list.add(testA1);
        list.add(testA2);
        list.add(testA3);
        System.out.println("排序前--:"+list.toString());
        Collections.sort(list, new Comparator<TestA>() {
            @Override
            public int compare(TestA o1, TestA o2) {
                //升序
                return o1.getAge().compareTo(o2.getAge());
            }
        });
        System.out.println("升序排序后--:"+list.toString());

        Collections.sort(list, new Comparator<TestA>() {
            @Override
            public int compare(TestA o1, TestA o2) {
                //降序
                return o2.getAge().compareTo(o1.getAge());
            }
        });
        System.out.println("降序排序后--:"+list.toString());

    }

}
復制代碼

輸出的是啥:

附:本文大部分參考網上資源,主要用於個人的筆記心得記錄

 

下面是個人在處理業務中的使用:

到了這里你覺得很神奇?錯了,現在是java8的時代,我們來看看新特性下如何排序的:

List<CountCardDetailVo> all = new ArrayList<>();
//根據創建時間降序排序
all.sort(Comparator.comparing(CountCardDetailVo::getCreateTime).reversed());
//根據創建時間升序排序
all.sort(Comparator.comparing(CountCardDetailVo::getCreateTime));

 

 

是不是很簡單,很奇跡,很強大~~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM