Comparator: Difference between revisions
Jump to navigation
Jump to search
Line 42: | Line 42: | ||
* [https://docs.oracle.com/javase/10/docs/api/java/util/Comparator.html#reversed() reversed()] | * [https://docs.oracle.com/javase/10/docs/api/java/util/Comparator.html#reversed() reversed()] | ||
* [https://docs.oracle.com/javase/10/docs/api/java/util/Comparator.html#thenComparing(java.util.function.Function) thenComparing(Function)] |
Revision as of 19:19, 26 March 2018
External
Internal
Overview
@FunctionalInterface
public interface Comparator<T> {
int compare(T o1, T o2);
...
}
Concise Sorting
Java 8 List has a sort() method that accepts a java.util.Comparator.
java.util.Comparator is a functional interface, so we can provide a lambda expression instead.
java.util.Comparator comes with static methods that build Comparator instances, so if compare apples by weight, we can write this:
List<Apple> apples = ...
apples.sort(Comparator.comparing(a -> a.getWeight()));
The last form can be compacted even further using method references:
List<Apple> apples = ...
apples.sort(Comparator.comparing(Apple::getWeight));