JDK8的排序大法!!
生活随笔
收集整理的這篇文章主要介紹了
JDK8的排序大法!!
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
轉(zhuǎn)載自?屌炸天,JDK8的排序大法!!
今天總結(jié)了下JDK中排序的方法,包括JDK8中強大的lambda表達式及函數(shù)式接口運用,不廢話,請看下面示例。
public class Test {public static void main(String[] args) {List<User> list = initList();// jdk8之前的排序Collections.sort(list, new?Comparator<User>() {@Overridepublic int compare(User o1, User o2) {return o1.getAge().compareTo(o2.getAge());}});// jdk8 lambda排序,帶參數(shù)類型list = initList();list.sort((User u1, User u2) -> u1.getAge().compareTo(u2.getAge()));list.forEach(System.out::println);System.out.println();// jdk8 lambda排序,不帶參數(shù)類型list = initList();list.sort((u1, u2) -> u1.getAge().compareTo(u2.getAge()));list.forEach(System.out::println);System.out.println();// jdk8 排序,User類靜態(tài)方法引用list = initList();list.sort(User::compareAge);list.forEach(System.out::println);System.out.println();// jdk8 升序排序,Comparator提供的靜態(tài)方法list = initList();Collections.sort(list, Comparator.comparing(User::getAge));list.forEach(System.out::println);System.out.println();// jdk8 降序排序,Comparator提供的靜態(tài)方法list = initList();Collections.sort(list, Comparator.comparing(User::getAge).reversed());list.forEach(System.out::println);System.out.println();// jdk8 組合排序,Comparator提供的靜態(tài)方法,先按年紀排序,年紀相同的按名稱排序list = initList();Collections.sort(list, Comparator.comparing(User::getAge).thenComparing(User::getName));list.forEach(System.out::println);}private static List<User> initList() {List<User> list = new ArrayList<>();list.add(new User("lisa", 23));list.add(new User("tom", 11));list.add(new User("john", 16));list.add(new User("jennis", 26));list.add(new User("tin", 26));list.add(new User("army", 26));list.add(new User("mack", 19));list.add(new User("jobs", 65));return list;} }?
總結(jié)
以上是生活随笔為你收集整理的JDK8的排序大法!!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何quot;优雅quot;地终止一个线
- 下一篇: JDK8新特性之函数式接口