1:传统排序方法
/** * 常规升排序 */ public static void sortTest() { List<User> list = new ArrayList <>( ); list.add( new User( "a",1 ) ); list.add( new User( "f",6 ) ); list.add( new User( "d",7 ) ); list.add( new User( "f",0 ) ); list.add( new User( "q",12 ) ); //按照id排序 Collections.sort( list, new Comparator <User>( ) { @Override public int compare(User o1, User o2) { return o1.getId() - o2.getId(); //o2.getId() - o1.getId() 降序 //o1.getId() - o2.getId() 升序 } } ); //按照name排序。只需要重写匿名内部类就可以 Collections.sort( list, new Comparator <User>( ) { @Override public int compare(User o1, User o2) { return o1.getName().compareTo( o2.getName() ); //o1.getName().compareTo( o2.getName() ); //o2.getName().compareTo( o1.getName() ) } } ); //遍历结果,是否排序 for (User u :list) { System.out.println(u); } /** * 升序 Collections.sort(list) * 降序 Collections.reserve(list) * 随机 Collections.shuffle(list) */ }
2:Lambda排序
/** * Lambda排序 * /** * 升序 Collections.sort(list) * 降序 Collections.reserve(list) * 随机 Collections.shuffle(list) */ public static void lambdaTest() { List<User> list = getList(); //排序 降序 list.sort((o1, o2) -> o2.getId() - o1.getId()); //排序 升序 list.sort((o1, o2) -> o1.getId() - o2.getId()); //遍历 list.forEach( System.out::println); }
/** * 多条件组合排序 * /** * 升序 Collections.sort(list) * 降序 Collections.reserve(list) * 随机 Collections.shuffle(list) */ public static void lambdaTest02() { List<User> list = getList(); list.sort(Comparator .comparing(User::getId).reversed() .thenComparing(Comparator.comparing(User::getName)).reversed() ); list.forEach( user ->System.out.println(user));/** * 获取 list * @return */ public static List<User> getList() { List<User> list = new ArrayList <>( ) ; list.add( new User( "a" , 1 ) ) ; list.add( new User( "f" , 6 ) ) ; list.add( new User( "d" , 7 ) ) ; list.add( new User( "k" , 0 ) ) ; list.add( new User( "d" , 56 ) ) ; list.add( new User( "g" , 125 ) ) ; list.add( new User( "u" , 25 ) ) ; list.add( new User( "y" , 87 ) ) ; list.add( new User( "t" , 53)) ; list.add( new User( "r" , 123 ) ) ; list.add( new User( "e" , 987 ) ) ; list.add( new User( "q" , 4 ) ) ; return list ;