1. 實體類:Student.java
package java8newfeture; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import com.google.common.collect.Lists; /** * @author zero 2019/01/26 */ public class Student { private int id; private String name; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Student() { } /** * @param id * @param name */ public Student(int id, String name) { super(); this.id = id; this.name = name; } @Override public String toString() { return "Student [id=" + id + ", name=" + name + "]"; } }
2. 測試類:SortStudent.java
package java8newfeture; import java.util.ArrayList; import java.util.Comparator; import com.google.common.collect.Lists; /** * @author zero 2019/01/26 */ public class SortStudent { public static void main(String[] args) { ArrayList<Student> students = Lists.newArrayList(new Student(1, "A2"),new Student(1, "A1"), new Student(3, "C3"), new Student(2, "B2")); // 默認是升序排序,降序為comparing(Student::getId).reversed().thComparing(Student::getName)
// 如果是需要按照某個字段降序排序,則在后面調用方法reversed() students.sort(Comparator.comparing(Student::getId).thenComparing(Student::getName)); students.forEach(System.out::println); } }
3. 測試結果:
4. 結論:親測有效,請自己擴展嘗試!