Few examples to show you how to sort a List
with stream.sorted()
1. List
1.1 Sort a List with Comparator.naturalOrder()
package com.favtuts.java8.stream; import java.util.Arrays; import java.util.List; import java.util.stream.Collectors; public class StreamSortList { public static void main(String[] args) { sortListWithComparatorNaturalOrder(); } static void sortListWithComparatorNaturalOrder() { List<String> list = Arrays.asList("9", "A", "Z", "1", "B", "Y", "4", "a", "c"); /* * List<String> sortedList = list.stream() * .sorted(Comparator.naturalOrder()) * .collect(Collectors.toList()); * * List<String> sortedList = list.stream() * .sorted((o1,o2)-> o1.compareTo(o2)) * .collect(Collectors.toList()); */ List<String> sortedList = list.stream().sorted().collect(Collectors.toList()); sortedList.forEach(System.out::println); } }
Output
1
4
9
A
B
Y
Z
a
c
1.2 Sort a List with Comparator.reverseOrder()
package com.favtuts.java8.stream; import java.util.Arrays; import java.util.Comparator; import java.util.List; import java.util.stream.Collectors; public class StreamSortList { public static void main(String[] args) { sortListWithComparatorReverseOrder(); } static void sortListWithComparatorReverseOrder() { List<String> list = Arrays.asList("9", "A", "Z", "1", "B", "Y", "4", "a", "c"); /* * List<String> sortedList = list.stream() * .sorted((o1,o2)-> o2.compareTo(o1)) * .collect(Collectors.toList()); */ List<String> sortedList = list.stream() .sorted(Comparator.reverseOrder()) .collect(Collectors.toList()); sortedList.forEach(System.out::println); } }
Output
c
a
Z
Y
B
A
9
4
1
2. List Objects
1.1 Sort by age, natural order.
package com.favtuts.java8.stream; import java.util.Arrays; import java.util.Comparator; import java.util.List; import java.util.stream.Collectors; public class StreamSortList { static List<User> users = Arrays.asList( new User("C", 30), new User("D", 40), new User("A", 10), new User("B", 20), new User("E", 50)); public static void main(String[] args) { sortListObjectUserByAgeNaturalOrder(); } static void sortListObjectUserByAgeNaturalOrder() { /* * List<User> sortedList = users.stream() * .sorted((o1, o2) -> o1.getAge() - o2.getAge()) * .collect(Collectors.toList()); */ List<User> sortedList = users.stream() .sorted(Comparator.comparingInt(User::getAge)) .collect(Collectors.toList()); sortedList.forEach(System.out::println); } static class User { private String name; private int age; public User(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User{" + "name='" + name + '\'' + ", age=" + age + '}'; } } }
Output
User{name='A', age=10}
User{name='B', age=20}
User{name='C', age=30}
User{name='D', age=40}
User{name='E', age=50}
1.2 reverse order.
List<User> sortedList = users.stream() .sorted(Comparator.comparingInt(User::getAge).reversed()) .collect(Collectors.toList()); sortedList.forEach(System.out::println);
Output
User{name='E', age=50}
User{name='D', age=40}
User{name='C', age=30}
User{name='B', age=20}
User{name='A', age=10}
1.3 Sort by name
/* * List<User> sortedList = users.stream() * .sorted((o1, o2) -> o1.getName().compareTo(o2.getName())) * .collect(Collectors.toList()); */ List<User> sortedList = users.stream() .sorted(Comparator.comparing(User::getName)) .collect(Collectors.toList()); sortedList.forEach(System.out::println);
Download Source Code
$ git clone https://github.com/favtuts/java-core-tutorials-examples
$ cd java-basic/java8/stream