Java 8 fornece diferentes métodos de API de utilitário para nos ajudar a classificar melhor os fluxos.
Se a sua lista for uma lista de inteiros (ou Double, Long, String, etc.), então você pode simplesmente classificar a lista com comparadores padrão fornecidos por java.
List<Integer> integerList = Arrays.asList(1, 4, 3, 4, 5);
Criando comparador em tempo real:
integerList.stream().sorted((i1, i2) -> i1.compareTo(i2)).forEach(System.out::println);
Com o comparador padrão fornecido por java 8 quando nenhum argumento for passado para Sort ():
integerList.stream().sorted().forEach(System.out::println); //Natural order
Se você deseja classificar a mesma lista na ordem inversa:
integerList.stream().sorted(Comparator.reverseOrder()).forEach(System.out::println); // Reverse Order
Se a sua lista for uma lista de objetos definidos pelo usuário, então:
List<Person> personList = Arrays.asList(new Person(1000, "First", 25, 30000),
new Person(2000, "Second", 30, 45000),
new Person(3000, "Third", 35, 25000));
Criando comparador em tempo real:
personList.stream().sorted((p1, p2) -> ((Long)p1.getPersonId()).compareTo(p2.getPersonId()))
.forEach(person -> System.out.println(person.getName()));
Usando o método Comparator.comparingLong () (também temos os métodos comparingDouble () e comparingInt ()):
personList.stream().sorted(Comparator.comparingLong(Person::getPersonId)).forEach(person -> System.out.println(person.getName()));
Usando o método Comparator.comparing () (método genérico que compara com base no método getter fornecido):
personList.stream().sorted(Comparator.comparing(Person::getPersonId)).forEach(person -> System.out.println(person.getName()));
Podemos fazer o encadeamento também usando o método Comparing ():
personList.stream().sorted(Comparator.comparing(Person::getPersonId).thenComparing(Person::getAge)).forEach(person -> System.out.println(person.getName())); //Sorting by person id and then by age.
Classe pessoal
public class Person {
private long personId;
private String name;
private int age;
private double salary;
public long getPersonId() {
return personId;
}
public void setPersonId(long personId) {
this.personId = personId;
}
public Person(long personId, String name, int age, double salary) {
this.personId = personId;
this.name = name;
this.age = age;
this.salary = salary;
}
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;
}
public double getSalary() {
return salary;
}
public void setSalary(double salary) {
this.salary = salary;
}
}
list.sort(Comparator.comparing(o -> o.getItem().getValue()));
era novo para mim. Ótimo!