public class IterableUtils
extends java.lang.Object
Iterable
instances.
Note: this util class has been designed for fail-fast argument checking.
NullPointerException
if a null Iterable is passed as argument.
Predicate
, will result in a NullPointerException
. Exception: passing
a null Comparator
is equivalent to a Comparator with natural ordering.
Constructor and Description |
---|
IterableUtils() |
Modifier and Type | Method and Description |
---|---|
static <E> java.lang.Iterable<E> |
boundedIterable(java.lang.Iterable<E> iterable,
long maxSize)
Returns a view of the given iterable that contains at most the given number
of elements.
|
static <E> java.lang.Iterable<E> |
chainedIterable(java.lang.Iterable<? extends E>... iterables)
Combines the provided iterables into a single iterable.
|
static <E> java.lang.Iterable<E> |
chainedIterable(java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b)
Combines two iterables into a single iterable.
|
static <E> java.lang.Iterable<E> |
chainedIterable(java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b,
java.lang.Iterable<? extends E> c)
Combines three iterables into a single iterable.
|
static <E> java.lang.Iterable<E> |
chainedIterable(java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b,
java.lang.Iterable<? extends E> c,
java.lang.Iterable<? extends E> d)
Combines four iterables into a single iterable.
|
static <E> java.lang.Iterable<E> |
collatedIterable(java.util.Comparator<? super E> comparator,
java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b)
Combines the two provided iterables into an ordered iterable using the
provided comparator.
|
static <E> java.lang.Iterable<E> |
collatedIterable(java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b)
Combines the two provided iterables into an ordered iterable using
natural ordering.
|
static <E> boolean |
contains(java.lang.Iterable<? extends E> iterable,
E object,
Equator<? super E> equator)
Checks if the object is contained in the given iterable.
|
static <E> boolean |
contains(java.lang.Iterable<E> iterable,
java.lang.Object object)
Checks if the object is contained in the given iterable.
|
static <E> long |
countMatches(java.lang.Iterable<E> input,
Predicate<? super E> predicate)
Counts the number of elements in the input iterable that match the predicate.
|
static <E> java.lang.Iterable<E> |
emptyIfNull(java.lang.Iterable<E> iterable)
Returns an immutable empty iterable if the argument is null,
or the argument itself otherwise.
|
static <E> java.lang.Iterable<E> |
emptyIterable()
Gets an empty iterable.
|
static <E> java.lang.Iterable<E> |
filteredIterable(java.lang.Iterable<E> iterable,
Predicate<? super E> predicate)
Returns a view of the given iterable that only contains elements matching
the provided predicate.
|
static <E> E |
find(java.lang.Iterable<E> iterable,
Predicate<? super E> predicate)
Finds the first element in the given iterable which matches the given predicate.
|
static <T> T |
first(java.lang.Iterable<T> iterable)
Shortcut for
get(iterator, 0) . |
static <E> void |
forEach(java.lang.Iterable<E> iterable,
Closure<? super E> closure)
Applies the closure to each element of the provided iterable.
|
static <E> E |
forEachButLast(java.lang.Iterable<E> iterable,
Closure<? super E> closure)
Executes the given closure on each but the last element in the iterable.
|
static <E,T extends E> |
frequency(java.lang.Iterable<E> iterable,
T obj)
Returns the number of occurrences of the provided object in the iterable.
|
static <T> T |
get(java.lang.Iterable<T> iterable,
int index)
Returns the
index -th value in the iterable 's Iterator , throwing
IndexOutOfBoundsException if there is no such element. |
static <E> int |
indexOf(java.lang.Iterable<E> iterable,
Predicate<? super E> predicate)
Returns the index of the first element in the specified iterable that
matches the given predicate.
|
static boolean |
isEmpty(java.lang.Iterable<?> iterable)
Answers true if the provided iterable is empty.
|
static <E> java.lang.Iterable<E> |
loopingIterable(java.lang.Iterable<E> iterable)
Returns a view of the given iterable which will cycle infinitely over
its elements.
|
static <E> boolean |
matchesAll(java.lang.Iterable<E> iterable,
Predicate<? super E> predicate)
Answers true if a predicate is true for every element of an iterable.
|
static <E> boolean |
matchesAny(java.lang.Iterable<E> iterable,
Predicate<? super E> predicate)
Answers true if a predicate is true for any element of the iterable.
|
static <O,R extends java.util.Collection<O>> |
partition(java.lang.Iterable<? extends O> iterable,
Factory<R> partitionFactory,
Predicate<? super O>... predicates)
Partitions all elements from iterable into separate output collections,
based on the evaluation of the given predicates.
|
static <O> java.util.List<java.util.List<O>> |
partition(java.lang.Iterable<? extends O> iterable,
Predicate<? super O>... predicates)
Partitions all elements from iterable into separate output collections,
based on the evaluation of the given predicates.
|
static <O> java.util.List<java.util.List<O>> |
partition(java.lang.Iterable<? extends O> iterable,
Predicate<? super O> predicate)
Partitions all elements from iterable into separate output collections,
based on the evaluation of the given predicate.
|
static <E> java.lang.Iterable<E> |
reversedIterable(java.lang.Iterable<E> iterable)
Returns a reversed view of the given iterable.
|
static int |
size(java.lang.Iterable<?> iterable)
Returns the number of elements contained in the given iterator.
|
static <E> java.lang.Iterable<E> |
skippingIterable(java.lang.Iterable<E> iterable,
long elementsToSkip)
Returns a view of the given iterable that skips the first N elements.
|
static <E> java.util.List<E> |
toList(java.lang.Iterable<E> iterable)
Gets a new list with the contents of the provided iterable.
|
static <E> java.lang.String |
toString(java.lang.Iterable<E> iterable)
Returns a string representation of the elements of the specified iterable.
|
static <E> java.lang.String |
toString(java.lang.Iterable<E> iterable,
Transformer<? super E,java.lang.String> transformer)
Returns a string representation of the elements of the specified iterable.
|
static <E> java.lang.String |
toString(java.lang.Iterable<E> iterable,
Transformer<? super E,java.lang.String> transformer,
java.lang.String delimiter,
java.lang.String prefix,
java.lang.String suffix)
Returns a string representation of the elements of the specified iterable.
|
static <I,O> java.lang.Iterable<O> |
transformedIterable(java.lang.Iterable<I> iterable,
Transformer<? super I,? extends O> transformer)
Returns a transformed view of the given iterable where all of its elements
have been transformed by the provided transformer.
|
static <E> java.lang.Iterable<E> |
uniqueIterable(java.lang.Iterable<E> iterable)
Returns a unique view of the given iterable.
|
static <E> java.lang.Iterable<E> |
unmodifiableIterable(java.lang.Iterable<E> iterable)
Returns an unmodifiable view of the given iterable.
|
static <E> java.lang.Iterable<E> |
zippingIterable(java.lang.Iterable<? extends E> first,
java.lang.Iterable<? extends E>... others)
Interleaves two iterables into a single iterable.
|
static <E> java.lang.Iterable<E> |
zippingIterable(java.lang.Iterable<? extends E> a,
java.lang.Iterable<? extends E> b)
Interleaves two iterables into a single iterable.
|
public static <E> java.lang.Iterable<E> emptyIterable()
This iterable does not contain any elements.
E
- the element typepublic static <E> java.lang.Iterable<E> chainedIterable(java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b)
The returned iterable has an iterator that traverses the elements in a
,
followed by the elements in b
. The source iterators are not polled until
necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typea
- the first iterable, may not be nullb
- the second iterable, may not be nulljava.lang.NullPointerException
- if either a or b is nullpublic static <E> java.lang.Iterable<E> chainedIterable(java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b, java.lang.Iterable<? extends E> c)
The returned iterable has an iterator that traverses the elements in a
,
followed by the elements in b
and c
. The source iterators are
not polled until necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typea
- the first iterable, may not be nullb
- the second iterable, may not be nullc
- the third iterable, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> chainedIterable(java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b, java.lang.Iterable<? extends E> c, java.lang.Iterable<? extends E> d)
The returned iterable has an iterator that traverses the elements in a
,
followed by the elements in b
, c
and d
. The source
iterators are not polled until necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typea
- the first iterable, may not be nullb
- the second iterable, may not be nullc
- the third iterable, may not be nulld
- the fourth iterable, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> chainedIterable(java.lang.Iterable<? extends E>... iterables)
The returned iterable has an iterator that traverses the elements in the order of the arguments, i.e. iterables[0], iterables[1], .... The source iterators are not polled until necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typeiterables
- the iterables to combine, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> collatedIterable(java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b)
The returned iterable's iterator supports remove()
when the
corresponding input iterator supports it.
E
- the element typea
- the first iterable, may not be nullb
- the second iterable, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> collatedIterable(java.util.Comparator<? super E> comparator, java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b)
The returned iterable's iterator supports remove()
when the
corresponding input iterator supports it.
E
- the element typecomparator
- the comparator defining an ordering over the elements,
may be null, in which case natural ordering will be useda
- the first iterable, may not be nullb
- the second iterable, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> filteredIterable(java.lang.Iterable<E> iterable, Predicate<? super E> predicate)
The returned iterable's iterator supports remove()
when the
corresponding input iterator supports it.
E
- the element typeiterable
- the iterable to filter, may not be nullpredicate
- the predicate used to filter elements, may not be nulljava.lang.NullPointerException
- if either iterable or predicate is nullpublic static <E> java.lang.Iterable<E> boundedIterable(java.lang.Iterable<E> iterable, long maxSize)
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typeiterable
- the iterable to limit, may not be nullmaxSize
- the maximum number of elements, must not be negativejava.lang.IllegalArgumentException
- if maxSize is negativejava.lang.NullPointerException
- if iterable is nullpublic static <E> java.lang.Iterable<E> loopingIterable(java.lang.Iterable<E> iterable)
The returned iterable's iterator supports remove()
if
iterable.iterator()
does. After remove()
is called, subsequent
cycles omit the removed element, which is no longer in iterable
. The
iterator's hasNext()
method returns true
until iterable
is empty.
E
- the element typeiterable
- the iterable to loop, may not be nulljava.lang.NullPointerException
- if iterable is nullpublic static <E> java.lang.Iterable<E> reversedIterable(java.lang.Iterable<E> iterable)
In case the provided iterable is a List
instance, a
ReverseListIterator
will be used to reverse the traversal
order, otherwise an intermediate List
needs to be created.
The returned iterable's iterator supports remove()
if the
provided iterable is a List
instance.
E
- the element typeiterable
- the iterable to use, may not be nulljava.lang.NullPointerException
- if iterable is nullReverseListIterator
public static <E> java.lang.Iterable<E> skippingIterable(java.lang.Iterable<E> iterable, long elementsToSkip)
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typeiterable
- the iterable to use, may not be nullelementsToSkip
- the number of elements to skip from the start, must not be negativejava.lang.IllegalArgumentException
- if elementsToSkip is negativejava.lang.NullPointerException
- if iterable is nullpublic static <I,O> java.lang.Iterable<O> transformedIterable(java.lang.Iterable<I> iterable, Transformer<? super I,? extends O> transformer)
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
I
- the input element typeO
- the output element typeiterable
- the iterable to transform, may not be nulltransformer
- the transformer, must not be nulljava.lang.NullPointerException
- if either iterable or transformer is nullpublic static <E> java.lang.Iterable<E> uniqueIterable(java.lang.Iterable<E> iterable)
The returned iterable's iterator supports remove()
when the
corresponding input iterator supports it. Calling remove()
will only remove a single element from the underlying iterator.
E
- the element typeiterable
- the iterable to use, may not be nulljava.lang.NullPointerException
- if iterable is nullpublic static <E> java.lang.Iterable<E> unmodifiableIterable(java.lang.Iterable<E> iterable)
The returned iterable's iterator does not support remove()
.
E
- the element typeiterable
- the iterable to use, may not be nulljava.lang.NullPointerException
- if iterable is nullpublic static <E> java.lang.Iterable<E> zippingIterable(java.lang.Iterable<? extends E> a, java.lang.Iterable<? extends E> b)
The returned iterable has an iterator that traverses the elements in a
and b
in alternating order. The source iterators are not polled until
necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typea
- the first iterable, may not be nullb
- the second iterable, may not be nulljava.lang.NullPointerException
- if either a or b is nullpublic static <E> java.lang.Iterable<E> zippingIterable(java.lang.Iterable<? extends E> first, java.lang.Iterable<? extends E>... others)
The returned iterable has an iterator that traverses the elements in a
and b
in alternating order. The source iterators are not polled until
necessary.
The returned iterable's iterator supports remove()
when the corresponding
input iterator supports it.
E
- the element typefirst
- the first iterable, may not be nullothers
- the array of iterables to interleave, may not be nulljava.lang.NullPointerException
- if either of the provided iterables is nullpublic static <E> java.lang.Iterable<E> emptyIfNull(java.lang.Iterable<E> iterable)
E
- the element typeiterable
- the iterable, may be nullpublic static <E> void forEach(java.lang.Iterable<E> iterable, Closure<? super E> closure)
E
- the element typeiterable
- the iterator to use, may be nullclosure
- the closure to apply to each element, may not be nulljava.lang.NullPointerException
- if closure is nullpublic static <E> E forEachButLast(java.lang.Iterable<E> iterable, Closure<? super E> closure)
If the input iterable is null no change is made.
E
- the type of object the Iterable
containsiterable
- the iterable to get the input from, may be nullclosure
- the closure to perform, may not be nullpublic static <E> E find(java.lang.Iterable<E> iterable, Predicate<? super E> predicate)
A null
or empty iterator returns null.
E
- the element typeiterable
- the iterable to search, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static <E> int indexOf(java.lang.Iterable<E> iterable, Predicate<? super E> predicate)
A null
or empty iterable returns -1.
E
- the element typeiterable
- the iterable to search, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static <E> boolean matchesAll(java.lang.Iterable<E> iterable, Predicate<? super E> predicate)
A null
or empty iterable returns true.
E
- the type of object the Iterable
containsiterable
- the Iterable
to use, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static <E> boolean matchesAny(java.lang.Iterable<E> iterable, Predicate<? super E> predicate)
A null
or empty iterable returns false.
E
- the type of object the Iterable
containsiterable
- the Iterable
to use, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static <E> long countMatches(java.lang.Iterable<E> input, Predicate<? super E> predicate)
A null
iterable matches no elements.
E
- the type of object the Iterable
containsinput
- the Iterable
to get the input from, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static boolean isEmpty(java.lang.Iterable<?> iterable)
A null
iterable returns true.
iterable
- the to use
, may be nullpublic static <E> boolean contains(java.lang.Iterable<E> iterable, java.lang.Object object)
A null
or empty iterable returns false.
E
- the type of object the Iterable
containsiterable
- the iterable to check, may be nullobject
- the object to checkpublic static <E> boolean contains(java.lang.Iterable<? extends E> iterable, E object, Equator<? super E> equator)
equator
unlike contains(Iterable, Object)
which uses Object.equals(Object)
.
A null
or empty iterable returns false.
A null
object will not be passed to the equator, instead a
NullPredicate
will be used.
E
- the type of object the Iterable
containsiterable
- the iterable to check, may be nullobject
- the object to checkequator
- the equator to use to check, may not be nulljava.lang.NullPointerException
- if equator is nullpublic static <E,T extends E> int frequency(java.lang.Iterable<E> iterable, T obj)
E
- the element type that the Iterable
may containT
- the element type of the object to finditerable
- the Iterable
to searchobj
- the object to find the cardinality ofpublic static <T> T get(java.lang.Iterable<T> iterable, int index)
index
-th value in the iterable
's Iterator
, throwing
IndexOutOfBoundsException
if there is no such element.
If the Iterable
is a List
, then it will use List.get(int)
.
T
- the type of object in the Iterable
.iterable
- the Iterable
to get a value from, may be nullindex
- the index to getjava.lang.IndexOutOfBoundsException
- if the index is invalidpublic static <T> T first(java.lang.Iterable<T> iterable)
get(iterator, 0)
.
Returns the first
value in the iterable
's Iterator
, throwing
IndexOutOfBoundsException
if there is no such element.
If the Iterable
is a List
, then it will use List.get(int)
.
T
- the type of object in the Iterable
.iterable
- the Iterable
to get a value from, may be nulljava.lang.IndexOutOfBoundsException
- if the request is invalidpublic static int size(java.lang.Iterable<?> iterable)
A null
or empty iterator returns 0
.
iterable
- the iterable to check, may be nullpublic static <O> java.util.List<java.util.List<O>> partition(java.lang.Iterable<? extends O> iterable, Predicate<? super O> predicate)
For each predicate, the result will contain a list holding all elements of the input iterable matching the predicate. The last list will hold all elements which didn't match any predicate:
[C1, R] = partition(I, P1) with I = input P1 = first predicate C1 = collection of elements matching P1 R = collection of elements rejected by all predicates
If the input iterable is null
, the same is returned as for an
empty iterable.
Example: for an input list [1, 2, 3, 4, 5] calling partition with a predicate [x < 3] will result in the following output: [[1, 2], [3, 4, 5]].
O
- the type of object the Iterable
containsiterable
- the iterable to partition, may be nullpredicate
- the predicate to use, may not be nulljava.lang.NullPointerException
- if predicate is nullpublic static <O> java.util.List<java.util.List<O>> partition(java.lang.Iterable<? extends O> iterable, Predicate<? super O>... predicates)
For each predicate, the result will contain a list holding all elements of the input iterable matching the predicate. The last list will hold all elements which didn't match any predicate:
[C1, C2, R] = partition(I, P1, P2) with I = input P1 = first predicate P2 = second predicate C1 = collection of elements matching P1 C2 = collection of elements matching P2 R = collection of elements rejected by all predicates
Note: elements are only added to the output collection of the first matching predicate, determined by the order of arguments.
If the input iterable is null
, the same is returned as for an
empty iterable.
Example: for an input list [1, 2, 3, 4, 5] calling partition with predicates [x < 3] and [x < 5] will result in the following output: [[1, 2], [3, 4], [5]].
O
- the type of object the Iterable
containsiterable
- the collection to get the input from, may be nullpredicates
- the predicates to use, may not be nulljava.lang.NullPointerException
- if any predicate is nullpublic static <O,R extends java.util.Collection<O>> java.util.List<R> partition(java.lang.Iterable<? extends O> iterable, Factory<R> partitionFactory, Predicate<? super O>... predicates)
For each predicate, the returned list will contain a collection holding all elements of the input iterable matching the predicate. The last collection contained in the list will hold all elements which didn't match any predicate:
[C1, C2, R] = partition(I, P1, P2) with I = input P1 = first predicate P2 = second predicate C1 = collection of elements matching P1 C2 = collection of elements matching P2 R = collection of elements rejected by all predicates
Note: elements are only added to the output collection of the first matching predicate, determined by the order of arguments.
If the input iterable is null
, the same is returned as for an
empty iterable.
If no predicates have been provided, all elements of the input collection
will be added to the rejected collection.
Example: for an input list [1, 2, 3, 4, 5] calling partition with predicates [x < 3] and [x < 5] will result in the following output: [[1, 2], [3, 4], [5]].
O
- the type of object the Iterable
containsR
- the type of the output Collection
iterable
- the collection to get the input from, may be nullpartitionFactory
- the factory used to create the output collectionspredicates
- the predicates to use, may not be nulljava.lang.NullPointerException
- if any predicate is nullpublic static <E> java.util.List<E> toList(java.lang.Iterable<E> iterable)
E
- the element typeiterable
- the iterable to use, may be nullpublic static <E> java.lang.String toString(java.lang.Iterable<E> iterable)
The string representation consists of a list of the iterable's elements,
enclosed in square brackets ("[]"
). Adjacent elements are separated
by the characters ", "
(a comma followed by a space). Elements are
converted to strings as by String.valueOf(Object)
.
E
- the element typeiterable
- the iterable to convert to a string, may be nulliterable
public static <E> java.lang.String toString(java.lang.Iterable<E> iterable, Transformer<? super E,java.lang.String> transformer)
The string representation consists of a list of the iterable's elements,
enclosed in square brackets ("[]"
). Adjacent elements are separated
by the characters ", "
(a comma followed by a space). Elements are
converted to strings as by using the provided transformer
.
E
- the element typeiterable
- the iterable to convert to a string, may be nulltransformer
- the transformer used to get a string representation of an elementiterable
java.lang.NullPointerException
- if transformer
is nullpublic static <E> java.lang.String toString(java.lang.Iterable<E> iterable, Transformer<? super E,java.lang.String> transformer, java.lang.String delimiter, java.lang.String prefix, java.lang.String suffix)
The string representation consists of a list of the iterable's elements,
enclosed by the provided prefix
and suffix
. Adjacent elements
are separated by the provided delimiter
. Elements are converted to
strings as by using the provided transformer
.
E
- the element typeiterable
- the iterable to convert to a string, may be nulltransformer
- the transformer used to get a string representation of an elementdelimiter
- the string to delimit elementsprefix
- the prefix, prepended to the string representationsuffix
- the suffix, appended to the string representationiterable
java.lang.NullPointerException
- if either transformer, delimiter, prefix or suffix is nullCopyright © 2010 - 2020 Adobe. All Rights Reserved