java8排序


參考:https://www.cnblogs.com/invoker-/p/7709411.html

1.准備

實體類

import lombok.AllArgsConstructor;
import lombok.Data;


@Data
@AllArgsConstructor
public class UserObj {
    private String name;
    private Integer age;
    private Integer credits;
}

測試類

package com.pu.helloworld;

import org.assertj.core.util.Lists;

import java.util.List;

public class TestJava8 {
    public static void main(String[] args) {
        List<UserObj> userObjs = Lists.newArrayList(
                new UserObj("aa",9,70),
                new UserObj("aa",2,50),
                new UserObj("aa",6,60),
                new UserObj("ee",3,80),
                new UserObj("dd",5,70),
                new UserObj("ee",6,99),
                new UserObj("ff",9,73)
        );

    }
}

2.按年齡排序

這里使用lambda表達式來代替匿名內部類,並且使用list接口下的sort方法(java8新增加),再鏈式輸出

   userObjs.sort(((o1, o2) -> o1.getAge()-o2.getAge()));
   userObjs.forEach(userObj -> System.out.println(userObj));

當然還可以通過方法引用進一步的簡化,這里使用Comparator下的comparingInt進行排序,使用User::getAge獲得年齡,默認從小到大正向排序

userObjs.sort(Comparator.comparingInt(UserObj::getAge));
userObjs.forEach(System.out::println);

輸出:

UserObj(name=aa, age=2, credits=50)
UserObj(name=ee, age=3, credits=80)
UserObj(name=dd, age=5, credits=70)
UserObj(name=aa, age=6, credits=60)
UserObj(name=ee, age=6, credits=99)
UserObj(name=aa, age=9, credits=70)
UserObj(name=ff, age=9, credits=73)

3.按年齡倒序

在比較器后面增加reversed即可,鏈式調用是java8的風格之一,同樣是閱讀性,原先的匿名內部類方法不僅閱讀困難,一個簡單的倒序也需要先去觀察o2-o1還是o1-o2才能得出,而Java8的方法不僅代碼簡潔,可讀性還很高,compare getAge讀出是通過年齡進行排序,reversed讀出是倒序。

userObjs.sort(Comparator.comparingInt(UserObj::getAge).reversed());
userObjs.forEach(System.out::println);

4.按姓名,年齡,積分排序

  • 在這里我們使用比較器的thenComparing實現鏈式調用
 userObjs.sort(Comparator.comparing(UserObj::getName)
                .thenComparing(UserObj::getAge)
                .thenComparing(UserObj::getCredits)
        );
        userObjs.forEach(System.out::println);

輸出:

UserObj(name=aa, age=2, credits=50)
UserObj(name=aa, age=6, credits=60)
UserObj(name=aa, age=9, credits=70)
UserObj(name=dd, age=5, credits=70)
UserObj(name=ee, age=3, credits=80)
UserObj(name=ee, age=6, credits=99)
UserObj(name=ff, age=9, credits=73)

按姓名升,年齡降,積分升排序

 userObjs.sort(Comparator.comparing(UserObj::getName)
                .thenComparing(UserObj::getAge,((o1, o2) -> o2-o1))
                .thenComparing(UserObj::getCredits)
        );

實上 o2 - o1 這樣的代碼還是有一些命令式的風格,即包含了具體的實現過程(o2 -o1這樣的代碼),thenComparaing方法可以直接接受一個排序器,因此我們只要直接將倒序的排序器當做參數傳入即可,代碼如下

        userObjs.sort(Comparator.comparing(UserObj::getName)
                .thenComparing(Comparator.comparing(UserObj::getAge).reversed())
                .thenComparing(UserObj::getCredits)
        );

 


免責聲明!

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



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