@GwtCompatible public abstract class Ordering<T> extends Objectimplements Comparator <T>
Comparator, in the same sense that
FluentIterable is an enriched
Iterable.
The common ways to get an instance of Ordering are:
compare(T, T) instead of implementing Comparator directly Comparator instance to from(Comparator) natural() Then you can use the chaining methods to get an altered version of that Ordering, including:
Finally, use the resulting Ordering anywhere a Comparator is required, or use any of its special operations, such as:
immutableSortedCopy(java.lang.Iterable<E>) isOrdered(java.lang.Iterable<? extends T>) / isStrictlyOrdered(java.lang.Iterable<? extends T>) min(java.util.Iterator<E>) / max(java.util.Iterator<E>) Except as noted, the orderings returned by the factory methods of this class are serializable if and only if the provided instances that back them are. For example, if ordering and function can themselves be serialized, then ordering.onResultOf(function) can as well.
See the Guava User Guide article on Ordering.
| Modifier | Constructor and Description |
|---|---|
protected |
Ordering()
Constructs a new instance of this class (only invokable by the subclass constructor, typically implicit).
|
| Modifier and Type | Method and Description |
|---|---|
static Ordering |
allEqual()
Returns an ordering which treats all values as equal, indicating "no ordering." Passing this ordering to any
stable sort algorithm results in no change to the order of elements.
|
static Ordering |
arbitrary()
Returns an arbitrary ordering over all objects, for which
compare(a, b) == 0 implies
a == b (identity equality).
|
int |
binarySearch(List
|
abstract int |
compare(T left, T right)
|
<U extends T> Ordering |
compound(Comparator
Returns an ordering which first uses the ordering
this, but which in the event of a "tie", then delegates to
secondaryComparator.
|
static <T> Ordering |
compound(Iterable
Returns an ordering which tries each given comparator in order until a non-zero result is found, returning that result, and returning zero only if all comparators return zero.
|
static <T> Ordering |
explicit(List
Returns an ordering that compares objects according to the order in which they appear in the given list.
|
static <T> Ordering |
explicit(T leastValue, T... remainingValuesInOrder)
Returns an ordering that compares objects according to the order in which they are given to this method.
|
static <T> Ordering |
from(Comparator
Returns an ordering based on an
existing comparator instance.
|
static <T> Ordering |
from(Ordering
Deprecated.
no need to use this
|
<E extends T> List |
greatestOf(Iterable
Returns the
k greatest elements of the given iterable according to this ordering, in order from greatest to least.
|
<E extends T> List |
greatestOf(Iterator
Returns the
k greatest elements from the given iterator according to this ordering, in order from greatest to least.
|
<E extends T> ImmutableList |
immutableSortedCopy(Iterable
Returns an
immutable list containing
elements sorted by this ordering.
|
boolean |
isOrdered(Iterable
Returns
true if each element in
iterable after the first is greater than or equal to the element that preceded it, according to this ordering.
|
boolean |
isStrictlyOrdered(Iterable
Returns
true if each element in
iterable after the first is
strictly greater than the element that preceded it, according to this ordering.
|
<E extends T> List |
leastOf(Iterable
Returns the
k least elements of the given iterable according to this ordering, in order from least to greatest.
|
<E extends T> List |
leastOf(Iterator
Returns the
k least elements from the given iterator according to this ordering, in order from least to greatest.
|
<S extends T> Ordering |
lexicographical()
Returns a new ordering which sorts iterables by comparing corresponding elements pairwise until a nonzero result is found; imposes "dictionary order".
|
<E extends T> E |
max(E a, E b)
Returns the greater of the two values according to this ordering.
|
<E extends T> E |
max(E a, E b, E c, E... rest)
Returns the greatest of the specified values according to this ordering.
|
<E extends T> E |
max(Iterable
Returns the greatest of the specified values according to this ordering.
|
<E extends T> E |
max(Iterator
Returns the greatest of the specified values according to this ordering.
|
<E extends T> E |
min(E a, E b)
Returns the lesser of the two values according to this ordering.
|
<E extends T> E |
min(E a, E b, E c, E... rest)
Returns the least of the specified values according to this ordering.
|
<E extends T> E |
min(Iterable
Returns the least of the specified values according to this ordering.
|
<E extends T> E |
min(Iterator
Returns the least of the specified values according to this ordering.
|
static <C extends Comparable |
natural()
Returns a serializable ordering that uses the natural order of the values.
|
<S extends T> Ordering |
nullsFirst()
Returns an ordering that treats
null as less than all other values and uses
this to compare non-null values.
|
<S extends T> Ordering |
nullsLast()
Returns an ordering that treats
null as greater than all other values and uses this ordering to compare non-null values.
|
<F> Ordering |
onResultOf(Function
Returns a new ordering on
F which orders elements by first applying a function to them, then comparing those results using
this.
|
<S extends T> Ordering |
reverse()
Returns the reverse of this ordering; the
Ordering equivalent to
Collections.
|
<E extends T> List |
sortedCopy(Iterable
Returns a
mutable list containing
elements sorted by this ordering; use this only when the resulting list may need further modification, or may contain
null.
|
static Ordering |
usingToString()
Returns an ordering that compares objects by the natural ordering of their string representations as returned by
toString().
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitcomparing, comparing, comparingDouble, comparingInt, comparingLong, equals, naturalOrder, nullsFirst, nullsLast, reversed, reverseOrder, thenComparing, thenComparing, thenComparing, thenComparingDouble, thenComparingInt, thenComparingLongprotected Ordering()
@GwtCompatible(serializable=true) public static <C extends Comparable> Ordering <C> natural()
NullPointerException when passed a null parameter.
The type specification is <C extends Comparable>, instead of the technically correct <C extends Comparable<? super C>>, to support legacy types from before Java 5.
@GwtCompatible(serializable=true) public static <T> Ordering<T> from(Comparator <T> comparator)
Comparator just to pass it in here. Instead, simply subclass
Ordering and implement its
compare method directly.
comparator - the comparator that defines the order
Ordering; otherwise an ordering that wraps that comparator
@GwtCompatible(serializable=true) @Deprecated public static <T> Ordering<T> from(Ordering <T> ordering)
@GwtCompatible(serializable=true) public static <T> Ordering<T> explicit(List <T> valuesInOrder)
Object.equals(java.lang.Object) ) may be compared. This comparator imposes a "partial ordering" over the type
T. Subsequent changes to the
valuesInOrder list will have no effect on the returned comparator. Null values in the list are not supported.
The returned comparator throws an ClassCastException when it receives an input parameter that isn't among the provided values.
The generated comparator is serializable if all the provided values are serializable.
valuesInOrder - the values that the returned comparator will be able to compare, in the order the comparator should induce
NullPointerException - if any of the provided values is null
IllegalArgumentException - if
valuesInOrder contains any duplicate values (according to
Object.equals(java.lang.Object) )
@GwtCompatible(serializable=true) public static <T> Ordering<T> explicit(T leastValue, T... remainingValuesInOrder)
Object.equals(java.lang.Object) ) may be compared. This comparator imposes a "partial ordering" over the type
T. Null values in the argument list are not supported.
The returned comparator throws a ClassCastException when it receives an input parameter that isn't among the provided values.
The generated comparator is serializable if all the provided values are serializable.
leastValue - the value which the returned comparator should consider the "least" of all values
remainingValuesInOrder - the rest of the values that the returned comparator will be able to compare, in the order the comparator should follow
NullPointerException - if any of the provided values is null
IllegalArgumentException - if any duplicate values (according to
Object.equals(Object) ) are present among the method arguments
@GwtCompatible(serializable=true) public static Ordering<Object > allEqual()
sortedCopy(java.lang.Iterable<E>) and
immutableSortedCopy(java.lang.Iterable<E>) are stable, and in the returned instance these are implemented by simply copying the source list.
Example:
Ordering.allEqual().nullsLast().sortedCopy( asList(t, null, e, s, null, t, null))
Assuming t, e and s are non-null, this returns [t, e, s, t, null, null, null] regardlesss of the true comparison order of those three values (which might not even implement Comparable at all).
Warning: by definition, this comparator is not consistent with equals (as defined here). Avoid its use in APIs, such as TreeSet, where such consistency is expected.
The returned comparator is serializable.
@GwtCompatible(serializable=true) public static Ordering<Object > usingToString()
toString(). It does not support null values.
The comparator is serializable.
public static Ordering<Object > arbitrary()
compare(a, b) == 0 implies
a == b (identity equality). There is no meaning whatsoever to the order imposed, but it is constant for the life of the VM.
Because the ordering is identity-based, it is not "consistent with Object" as defined by Comparator. Use caution when building a SortedSet or SortedMap from it, as the resulting collection will not behave exactly according to spec.
This ordering is not serializable, as its implementation relies on System, so its behavior cannot be preserved across serialization.
@GwtCompatible(serializable=true) public <S extends T> Ordering<S> reverse()
Ordering equivalent to
Collections.reverseOrder(Comparator) .
@GwtCompatible(serializable=true) public <S extends T> Ordering<S> nullsFirst()
null as less than all other values and uses
this to compare non-null values.
@GwtCompatible(serializable=true) public <S extends T> Ordering<S> nullsLast()
null as greater than all other values and uses this ordering to compare non-null values.
@GwtCompatible(serializable=true) public <F> Ordering<F> onResultOf(Function <F ,? extends T> function)
F which orders elements by first applying a function to them, then comparing those results using
this. For example, to compare objects by their string forms, in a case-insensitive manner, use:
Ordering.from(String.CASE_INSENSITIVE_ORDER) .onResultOf(Functions.toStringFunction())
@GwtCompatible(serializable=true) public <U extends T> Ordering<U> compound(Comparator <? super U> secondaryComparator)
this, but which in the event of a "tie", then delegates to
secondaryComparator. For example, to sort a bug list first by status and second by priority, you might use
byStatus.compound(byPriority). For a compound ordering with three or more components, simply chain multiple calls to this method.
An ordering produced by this method, or a chain of calls to this method, is equivalent to one created using compound(Iterable) on the same component comparators.
@GwtCompatible(serializable=true) public static <T> Ordering<T> compound(Iterable <? extends Comparator <? super T>> comparators)
comparators iterable at the time it was provided to this method.
The returned ordering is equivalent to that produced using Ordering.from(comp1).compound(comp2).compound(comp3) . . ..
Warning: Supplying an argument with undefined iteration order, such as a HashSet, will produce non-deterministic results.
comparators - the comparators to try in order
@GwtCompatible(serializable=true) public <S extends T> Ordering<Iterable <S>> lexicographical()
[] < [1] < [1, 1] < [1, 2] < [2].
Note that ordering.lexicographical().reverse() is not equivalent to ordering.reverse().lexicographical() (consider how each would order [1] and [1, 1]).
public <E extends T> E min(Iterator<E> iterator)
hasNext() method will return
false.
iterator - the iterator whose minimum element is to be determined
NoSuchElementException - if
iterator is empty
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E min(Iterable<E> iterable)
iterable - the iterable whose minimum element is to be determined
NoSuchElementException - if
iterable is empty
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E min(E a, E b)
Implementation note: this method is invoked by the default implementations of the other min overloads, so overriding it will affect their behavior.
a - value to compare, returned if less than or equal to b.
b - value to compare.
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E min(E a, E b, E c, E... rest)
a - value to compare, returned if less than or equal to the rest.
b - value to compare
c - value to compare
rest - values to compare
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E max(Iterator<E> iterator)
hasNext() method will return
false.
iterator - the iterator whose maximum element is to be determined
NoSuchElementException - if
iterator is empty
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E max(Iterable<E> iterable)
iterable - the iterable whose maximum element is to be determined
NoSuchElementException - if
iterable is empty
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E max(E a, E b)
Implementation note: this method is invoked by the default implementations of the other max overloads, so overriding it will affect their behavior.
a - value to compare, returned if greater than or equal to b.
b - value to compare.
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> E max(E a, E b, E c, E... rest)
a - value to compare, returned if greater than or equal to the rest.
b - value to compare
c - value to compare
rest - values to compare
ClassCastException - if the parameters are not
mutually comparable under this ordering.
public <E extends T> List<E> leastOf(Iterable <E> iterable, int k)
k least elements of the given iterable according to this ordering, in order from least to greatest. If there are fewer than
k elements present, all will be included.
The implementation does not necessarily use a stable sorting algorithm; when multiple elements are equivalent, it is undefined which will come first.
RandomAccess list of the
k least elements in ascending order
IllegalArgumentException - if
k is negative
public <E extends T> List<E> leastOf(Iterator <E> elements, int k)
k least elements from the given iterator according to this ordering, in order from least to greatest. If there are fewer than
k elements present, all will be included.
The implementation does not necessarily use a stable sorting algorithm; when multiple elements are equivalent, it is undefined which will come first.
RandomAccess list of the
k least elements in ascending order
IllegalArgumentException - if
k is negative
public <E extends T> List<E> greatestOf(Iterable <E> iterable, int k)
k greatest elements of the given iterable according to this ordering, in order from greatest to least. If there are fewer than
k elements present, all will be included.
The implementation does not necessarily use a stable sorting algorithm; when multiple elements are equivalent, it is undefined which will come first.
RandomAccess list of the
k greatest elements in
descending order
IllegalArgumentException - if
k is negative
public <E extends T> List<E> greatestOf(Iterator <E> iterator, int k)
k greatest elements from the given iterator according to this ordering, in order from greatest to least. If there are fewer than
k elements present, all will be included.
The implementation does not necessarily use a stable sorting algorithm; when multiple elements are equivalent, it is undefined which will come first.
RandomAccess list of the
k greatest elements in
descending order
IllegalArgumentException - if
k is negative
public <E extends T> List<E> sortedCopy(Iterable <E> elements)
elements sorted by this ordering; use this only when the resulting list may need further modification, or may contain
null. The input is not modified. The returned list is serializable and has random access.
Unlike Sets, this method does not discard elements that are duplicates according to the comparator. The sort performed is stable, meaning that such elements will appear in the returned list in the same order they appeared in elements.
Performance note: According to our benchmarking on Open JDK 7, immutableSortedCopy(java.lang.Iterable<E>) generally performs better (in both time and space) than this method, and this method in turn generally performs better than copying the list and calling Collections.
public <E extends T> ImmutableList<E> immutableSortedCopy(Iterable <E> elements)
elements sorted by this ordering. The input is not modified.
Unlike Sets, this method does not discard elements that are duplicates according to the comparator. The sort performed is stable, meaning that such elements will appear in the returned list in the same order they appeared in elements.
Performance note: According to our benchmarking on Open JDK 7, this method is the most efficient way to make a sorted copy of a collection.
NullPointerException - if any of
elements (or
elements itself) is null
public boolean isOrdered(Iterable<? extends T> iterable)
true if each element in
iterable after the first is greater than or equal to the element that preceded it, according to this ordering. Note that this is always true when the iterable has fewer than two elements.
public boolean isStrictlyOrdered(Iterable<? extends T> iterable)
true if each element in
iterable after the first is
strictly greater than the element that preceded it, according to this ordering. Note that this is always true when the iterable has fewer than two elements.