Comparator: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
 
(One intermediate revision by the same user not shown)
Line 26: Line 26:
@FunctionalInterface
@FunctionalInterface
public interface Comparator<T> {
public interface Comparator<T> {
static <T, U extends Comparable<? super U>> Comparator<T> comparing​(Function<? super T, ? extends U> keyExtractor);
static <T, U> Comparator<T> comparing​(Function<? super T, ? extends U> keyExtractor, Comparator<? super U> keyComparator);
}
}
</syntaxhighlight>
</syntaxhighlight>

Latest revision as of 19:38, 29 March 2018

External

Internal

Overview

@FunctionalInterface
public interface Comparator<T> {

    int compare(T o1, T o2);

    ...
}

Comparator.comparing()

Factory methods that produces comparator lambdas, based on various criteria.

@FunctionalInterface
public interface Comparator<T> {

 static <T, U extends Comparable<? super U>> Comparator<T> comparing(Function<? super T, ? extends U> keyExtractor);

 static <T, U> Comparator<T> comparing(Function<? super T, ? extends U> keyExtractor, Comparator<? super U> keyComparator);

}

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));

Composition Methods