Class FluentIterable<E extends @Nullable java.lang.Object>
- java.lang.Object
- 
- com.google.common.collect.FluentIterable<E>
 
- 
- All Implemented Interfaces:
- java.lang.Iterable<E>
 
 @GwtCompatible(emulated=true) public abstract class FluentIterable<E extends @Nullable java.lang.Object> extends java.lang.Object implements java.lang.Iterable<E> An expandedIterableAPI, providing functionality similar to Java 8's powerful streams library in a slightly different way.The following types of methods are provided: - chaining methods which return a new FluentIterablebased in some way on the contents of the current one (for exampletransform(com.google.common.base.Function<? super E, T>))
- element extraction methods which facilitate the retrieval of certain elements (for example
       last())
- query methods which answer questions about the FluentIterable's contents (for exampleanyMatch(com.google.common.base.Predicate<? super E>))
- conversion methods which copy the FluentIterable's contents into a new collection or array (for exampletoList())
 Several lesser-used features are currently available only as static methods on the Iterablesclass.Comparison to streamsStarting with Java 8, the core Java class libraries provide a new "Streams" library (in java.util.stream), which is similar toFluentIterablebut generally more powerful. Key differences include:- A stream is single-use; it becomes invalid as soon as any "terminal operation" such
       as findFirst()oriterator()is invoked. (Even thoughStreamcontains all the right method signatures to implementIterable, it does not actually do so, to avoid implying repeat-iterability.)FluentIterable, on the other hand, is multiple-use, and does implementIterable.
- Streams offer many features not found here, including min/max,distinct,reduce,sorted, the very powerfulcollect, and built-in support for parallelizing stream operations.
- FluentIterablecontains several features not available on- Stream, which are noted in the method descriptions below.
- Streams include primitive-specialized variants such as IntStream, the use of which is strongly recommended.
- Streams are standard Java, not requiring a third-party dependency (but do render your code incompatible with Java 7 and earlier).
 ExampleHere is an example that accepts a list from a database call, filters it based on a predicate, transforms it by invoking toString()on each element, and returns the first 10 elements as aList:
 The approximate stream equivalent is:ImmutableList<String> results = FluentIterable.from(database.getClientList()) .filter(Client::isActiveInLastMonth) .transform(Object::toString) .limit(10) .toList();List<String> results = database.getClientList() .stream() .filter(Client::isActiveInLastMonth) .map(Object::toString) .limit(10) .collect(Collectors.toList());- Since:
- 12.0
- Author:
- Marcin Mikosik
 
- 
- 
Constructor SummaryConstructors Modifier Constructor Description protectedFluentIterable()Constructor for use by subclasses.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description booleanallMatch(Predicate<? super E> predicate)Returnstrueif every element in this fluent iterable satisfies the predicate.booleananyMatch(Predicate<? super E> predicate)Returnstrueif any element in this fluent iterable satisfies the predicate.FluentIterable<E>append(E... elements)Returns a fluent iterable whose iterators traverse first the elements of this fluent iterable, followed byelements.FluentIterable<E>append(java.lang.Iterable<? extends E> other)Returns a fluent iterable whose iterators traverse first the elements of this fluent iterable, followed by those ofother.static <T extends @Nullable java.lang.Object>
 FluentIterable<T>concat(java.lang.Iterable<? extends java.lang.Iterable<? extends T>> inputs)Returns a fluent iterable that combines several iterables.static <T extends @Nullable java.lang.Object>
 FluentIterable<T>concat(java.lang.Iterable<? extends T>... inputs)Returns a fluent iterable that combines several iterables.static <T extends @Nullable java.lang.Object>
 FluentIterable<T>concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b)Returns a fluent iterable that combines two iterables.static <T extends @Nullable java.lang.Object>
 FluentIterable<T>concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b, java.lang.Iterable<? extends T> c)Returns a fluent iterable that combines three iterables.static <T extends @Nullable java.lang.Object>
 FluentIterable<T>concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b, java.lang.Iterable<? extends T> c, java.lang.Iterable<? extends T> d)Returns a fluent iterable that combines four iterables.booleancontains(java.lang.Object target)Returnstrueif this fluent iterable contains any object for whichequals(target)is true.<C extends java.util.Collection<? super E>>
 CcopyInto(C collection)Copies all the elements from this fluent iterable tocollection.FluentIterable<E>cycle()Returns a fluent iterable whoseIteratorcycles indefinitely over the elements of this fluent iterable.FluentIterable<E>filter(Predicate<? super E> predicate)Returns the elements from this fluent iterable that satisfy a predicate.<T> FluentIterable<T>filter(java.lang.Class<T> type)Returns the elements from this fluent iterable that are instances of classtype.Optional<@NonNull E>first()Returns anOptionalcontaining the first element in this fluent iterable.Optional<@NonNull E>firstMatch(Predicate<? super E> predicate)Returns anOptionalcontaining the first element in this fluent iterable that satisfies the given predicate, if such an element exists.static <E extends @Nullable java.lang.Object>
 FluentIterable<E>from(FluentIterable<E> iterable)Deprecated.instances ofFluentIterabledon't need to be converted toFluentIterablestatic <E extends @Nullable java.lang.Object>
 FluentIterable<E>from(E[] elements)Returns a fluent iterable containingelementsin the specified order.static <E extends @Nullable java.lang.Object>
 FluentIterable<E>from(java.lang.Iterable<E> iterable)Returns a fluent iterable that wrapsiterable, oriterableitself if it is already aFluentIterable.Eget(int position)Returns the element at the specified position in this fluent iterable.<K> ImmutableListMultimap<K,@NonNull E>index(Function<? super E,K> keyFunction)Creates an indexImmutableListMultimapthat contains the results of applying a specified function to each item in thisFluentIterableof values.booleanisEmpty()Determines whether this fluent iterable is empty.java.lang.Stringjoin(Joiner joiner)Returns aStringcontaining all of the elements of this fluent iterable joined withjoiner.Optional<@NonNull E>last()Returns anOptionalcontaining the last element in this fluent iterable.FluentIterable<E>limit(int maxSize)Creates a fluent iterable with the firstsizeelements of this fluent iterable.static <E extends @Nullable java.lang.Object>
 FluentIterable<E>of()Returns a fluent iterable containing no elements.static <E extends @Nullable java.lang.Object>
 FluentIterable<E>of(E element, E... elements)Returns a fluent iterable containing the specified elements in order.intsize()Returns the number of elements in this fluent iterable.FluentIterable<E>skip(int numberToSkip)Returns a view of this fluent iterable that skips its firstnumberToSkipelements.E[]toArray(java.lang.Class<@NonNull E> type)Returns an array containing all of the elements from this fluent iterable in iteration order.ImmutableList<@NonNull E>toList()Returns anImmutableListcontaining all of the elements from this fluent iterable in proper sequence.<V> ImmutableMap<@NonNull E,V>toMap(Function<? super E,V> valueFunction)Returns an immutable map whose keys are the distinct elements of thisFluentIterableand whose value for each key was computed byvalueFunction.ImmutableMultiset<@NonNull E>toMultiset()Returns anImmutableMultisetcontaining all of the elements from this fluent iterable.ImmutableSet<@NonNull E>toSet()Returns anImmutableSetcontaining all of the elements from this fluent iterable with duplicates removed.ImmutableList<@NonNull E>toSortedList(java.util.Comparator<? super E> comparator)Returns anImmutableListcontaining all of the elements from thisFluentIterablein the order specified bycomparator.ImmutableSortedSet<@NonNull E>toSortedSet(java.util.Comparator<? super E> comparator)Returns anImmutableSortedSetcontaining all of the elements from thisFluentIterablein the order specified bycomparator, with duplicates (determined bycomparator.compare(x, y) == 0) removed.java.lang.StringtoString()Returns a string representation of this fluent iterable, with the format[e1, e2, ..., en].<T extends @Nullable java.lang.Object>
 FluentIterable<T>transform(Function<? super E,T> function)Returns a fluent iterable that appliesfunctionto each element of this fluent iterable.<T extends @Nullable java.lang.Object>
 FluentIterable<T>transformAndConcat(Function<? super E,? extends java.lang.Iterable<? extends T>> function)Appliesfunctionto each element of this fluent iterable and returns a fluent iterable with the concatenated combination of results.<K> ImmutableMap<K,@NonNull E>uniqueIndex(Function<? super E,K> keyFunction)Returns a map with the contents of thisFluentIterableas itsvalues, indexed by keys derived from those values.
 
- 
- 
- 
Constructor Detail- 
FluentIterableprotected FluentIterable() Constructor for use by subclasses.
 
- 
 - 
Method Detail- 
frompublic static <E extends @Nullable java.lang.Object> FluentIterable<E> from(java.lang.Iterable<E> iterable) Returns a fluent iterable that wrapsiterable, oriterableitself if it is already aFluentIterable.Streamequivalent:iterable.stream()ifiterableis aCollection;StreamSupport.stream(iterable.spliterator(), false)otherwise.
 - 
frompublic static <E extends @Nullable java.lang.Object> FluentIterable<E> from(E[] elements) Returns a fluent iterable containingelementsin the specified order.The returned iterable is an unmodifiable view of the input array. Streamequivalent:Stream.of(T...).- Since:
- 20.0 (since 18.0 as an overload of of)
 
 - 
from@Deprecated @InlineMe(replacement="checkNotNull(iterable)", staticImports="com.google.common.base.Preconditions.checkNotNull") public static <E extends @Nullable java.lang.Object> FluentIterable<E> from(FluentIterable<E> iterable) Deprecated.instances ofFluentIterabledon't need to be converted toFluentIterableConstruct a fluent iterable from another fluent iterable. This is obviously never necessary, but is intended to help call out cases where one migration fromIterabletoFluentIterablehas obviated the need to explicitly convert to aFluentIterable.
 - 
concatpublic static <T extends @Nullable java.lang.Object> FluentIterable<T> concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b) Returns a fluent iterable that combines two iterables. The returned iterable has an iterator that traverses the elements ina, followed by the elements inb. The source iterators are not polled until necessary.The returned iterable's iterator supports remove()when the corresponding input iterator supports it.Streamequivalent:Stream#concat.- Since:
- 20.0
 
 - 
concatpublic static <T extends @Nullable java.lang.Object> FluentIterable<T> concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b, java.lang.Iterable<? extends T> c) Returns a fluent iterable that combines three iterables. The returned iterable has an iterator that traverses the elements ina, followed by the elements inb, followed by the elements inc. The source iterators are not polled until necessary.The returned iterable's iterator supports remove()when the corresponding input iterator supports it.Streamequivalent: use nested calls toStream#concat, or see the advice inconcat(Iterable...).- Since:
- 20.0
 
 - 
concatpublic static <T extends @Nullable java.lang.Object> FluentIterable<T> concat(java.lang.Iterable<? extends T> a, java.lang.Iterable<? extends T> b, java.lang.Iterable<? extends T> c, java.lang.Iterable<? extends T> d) Returns a fluent iterable that combines four iterables. The returned iterable has an iterator that traverses the elements ina, followed by the elements inb, followed by the elements inc, followed by the elements ind. The source iterators are not polled until necessary.The returned iterable's iterator supports remove()when the corresponding input iterator supports it.Streamequivalent: use nested calls toStream#concat, or see the advice inconcat(Iterable...).- Since:
- 20.0
 
 - 
concatpublic static <T extends @Nullable java.lang.Object> FluentIterable<T> concat(java.lang.Iterable<? extends T>... inputs) Returns a fluent iterable that combines several iterables. The returned iterable has an iterator that traverses the elements of each iterable ininputs. The input iterators are not polled until necessary.The returned iterable's iterator supports remove()when the corresponding input iterator supports it.Streamequivalent: to concatenate an arbitrary number of streams, useStream.of(stream1, stream2, ...).flatMap(s -> s). If the sources are iterables, useStream.of(iter1, iter2, ...).flatMap(Streams::stream).- Throws:
- java.lang.NullPointerException- if any of the provided iterables is- null
- Since:
- 20.0
 
 - 
concatpublic static <T extends @Nullable java.lang.Object> FluentIterable<T> concat(java.lang.Iterable<? extends java.lang.Iterable<? extends T>> inputs) Returns a fluent iterable that combines several iterables. The returned iterable has an iterator that traverses the elements of each iterable ininputs. The input iterators are not polled until necessary.The returned iterable's iterator supports remove()when the corresponding input iterator supports it. The methods of the returned iterable may throwNullPointerExceptionif any of the input iterators isnull.Streamequivalent:streamOfStreams.flatMap(s -> s)orstreamOfIterables.flatMap(Streams::stream). (SeeStreams#stream.)- Since:
- 20.0
 
 - 
ofpublic static <E extends @Nullable java.lang.Object> FluentIterable<E> of() Returns a fluent iterable containing no elements.Streamequivalent:Stream.empty().- Since:
- 20.0
 
 - 
ofpublic static <E extends @Nullable java.lang.Object> FluentIterable<E> of(E element, E... elements) Returns a fluent iterable containing the specified elements in order.Streamequivalent:Stream.of(T...).- Since:
- 20.0
 
 - 
toStringpublic java.lang.String toString() Returns a string representation of this fluent iterable, with the format[e1, e2, ..., en].Streamequivalent:stream.collect(Collectors.joining(", ", "[", "]"))or (less efficiently)stream.collect(Collectors.toList()).toString().- Overrides:
- toStringin class- java.lang.Object
 
 - 
sizepublic final int size() Returns the number of elements in this fluent iterable.Streamequivalent:stream.count().
 - 
containspublic final boolean contains(@CheckForNull java.lang.Object target) Returnstrueif this fluent iterable contains any object for whichequals(target)is true.Streamequivalent:stream.anyMatch(Predicate.isEqual(target)).
 - 
cyclepublic final FluentIterable<E> cycle() Returns a fluent iterable whoseIteratorcycles indefinitely over the elements of this fluent iterable.That iterator supports remove()ifiterable.iterator()does. Afterremove()is called, subsequent cycles omit the removed element, which is no longer in this fluent iterable. The iterator'shasNext()method returnstrueuntil this fluent iterable is empty.Warning: Typical uses of the resulting iterator may produce an infinite loop. You should use an explicit breakor be certain that you will eventually remove all the elements.Streamequivalent: if the source iterable has only a single elemente, useStream.generate(() -> e). Otherwise, collect your stream into a collection and useStream.generate(() -> collection).flatMap(Collection::stream).
 - 
appendpublic final FluentIterable<E> append(java.lang.Iterable<? extends E> other) Returns a fluent iterable whose iterators traverse first the elements of this fluent iterable, followed by those ofother. The iterators are not polled until necessary.The returned iterable's Iteratorsupportsremove()when the correspondingIteratorsupports it.Streamequivalent:Stream#concat.- Since:
- 18.0
 
 - 
appendpublic final FluentIterable<E> append(E... elements) Returns a fluent iterable whose iterators traverse first the elements of this fluent iterable, followed byelements.Streamequivalent:Stream.concat(thisStream, Stream.of(elements)).- Since:
- 18.0
 
 - 
filterpublic final FluentIterable<E> filter(Predicate<? super E> predicate) Returns the elements from this fluent iterable that satisfy a predicate. The resulting fluent iterable's iterator does not supportremove().Streamequivalent:Stream#filter(same).
 - 
filter@GwtIncompatible public final <T> FluentIterable<T> filter(java.lang.Class<T> type) Returns the elements from this fluent iterable that are instances of classtype.Streamequivalent:stream.filter(type::isInstance).map(type::cast). This does perform a little more work than necessary, so another option is to insert an unchecked cast at some later point:@SuppressWarnings("unchecked") // safe because of ::isInstance check ImmutableList<NewType> result = (ImmutableList) stream.filter(NewType.class::isInstance).collect(toImmutableList());
 - 
anyMatchpublic final boolean anyMatch(Predicate<? super E> predicate) Returnstrueif any element in this fluent iterable satisfies the predicate.Streamequivalent:Stream#anyMatch(same).
 - 
allMatchpublic final boolean allMatch(Predicate<? super E> predicate) Returnstrueif every element in this fluent iterable satisfies the predicate. If this fluent iterable is empty,trueis returned.Streamequivalent:Stream#allMatch(same).
 - 
firstMatchpublic final Optional<@NonNull E> firstMatch(Predicate<? super E> predicate) Returns anOptionalcontaining the first element in this fluent iterable that satisfies the given predicate, if such an element exists.Warning: avoid using a predicatethat matchesnull. Ifnullis matched in this fluent iterable, aNullPointerExceptionwill be thrown.Streamequivalent:stream.filter(predicate).findFirst().
 - 
transformpublic final <T extends @Nullable java.lang.Object> FluentIterable<T> transform(Function<? super E,T> function) Returns a fluent iterable that appliesfunctionto each element of this fluent iterable.The returned fluent iterable's iterator supports remove()if this iterable's iterator does. After a successfulremove()call, this fluent iterable no longer contains the corresponding element.Streamequivalent:Stream#map.
 - 
transformAndConcatpublic <T extends @Nullable java.lang.Object> FluentIterable<T> transformAndConcat(Function<? super E,? extends java.lang.Iterable<? extends T>> function) Appliesfunctionto each element of this fluent iterable and returns a fluent iterable with the concatenated combination of results.functionreturns an Iterable of results.The returned fluent iterable's iterator supports remove()if this function-returned iterables' iterator does. After a successfulremove()call, the returned fluent iterable no longer contains the corresponding element.Streamequivalent:Stream#flatMap(using a function that produces streams, not iterables).- Since:
- 13.0 (required Function<E, Iterable<T>>until 14.0)
 
 - 
firstpublic final Optional<@NonNull E> first() Returns anOptionalcontaining the first element in this fluent iterable. If the iterable is empty,Optional.absent()is returned.Streamequivalent: if the goal is to obtain any element,Stream#findAny; if it must specifically be the first element,Stream#findFirst.- Throws:
- java.lang.NullPointerException- if the first element is null; if this is a possibility, use- iterator().next()or- Iterables.getFirst(java.lang.Iterable<? extends T>, T)instead.
 
 - 
lastpublic final Optional<@NonNull E> last() Returns anOptionalcontaining the last element in this fluent iterable. If the iterable is empty,Optional.absent()is returned. If the underlyingiterableis aListwithRandomAccesssupport, then this operation is guaranteed to beO(1).Streamequivalent:stream.reduce((a, b) -> b).- Throws:
- java.lang.NullPointerException- if the last element is null; if this is a possibility, use- Iterables.getLast(java.lang.Iterable<T>)instead.
 
 - 
skippublic final FluentIterable<E> skip(int numberToSkip) Returns a view of this fluent iterable that skips its firstnumberToSkipelements. If this fluent iterable contains fewer thannumberToSkipelements, the returned fluent iterable skips all of its elements.Modifications to this fluent iterable before a call to iterator()are reflected in the returned fluent iterable. That is, the iterator skips the firstnumberToSkipelements that exist when the iterator is created, not whenskip()is called.The returned fluent iterable's iterator supports remove()if theIteratorof this fluent iterable supports it. Note that it is not possible to delete the last skipped element by immediately callingremove()on the returned fluent iterable's iterator, as theIteratorcontract states that a call to* remove()before a call tonext()will throw anIllegalStateException.Streamequivalent:Stream#skip(same).
 - 
limitpublic final FluentIterable<E> limit(int maxSize) Creates a fluent iterable with the firstsizeelements of this fluent iterable. If this fluent iterable does not contain that many elements, the returned fluent iterable will have the same behavior as this fluent iterable. The returned fluent iterable's iterator supportsremove()if this fluent iterable's iterator does.Streamequivalent:Stream#limit(same).- Parameters:
- maxSize- the maximum number of elements in the returned fluent iterable
- Throws:
- java.lang.IllegalArgumentException- if- sizeis negative
 
 - 
isEmptypublic final boolean isEmpty() Determines whether this fluent iterable is empty.Streamequivalent:!stream.findAny().isPresent().
 - 
toListpublic final ImmutableList<@NonNull E> toList() Returns anImmutableListcontaining all of the elements from this fluent iterable in proper sequence.Streamequivalent:ImmutableList.copyOf(stream.iterator()), or passImmutableList#toImmutableListtostream.collect().- Throws:
- java.lang.NullPointerException- if any element is- null
- Since:
- 14.0 (since 12.0 as toImmutableList()).
 
 - 
toSortedListpublic final ImmutableList<@NonNull E> toSortedList(java.util.Comparator<? super E> comparator) Returns anImmutableListcontaining all of the elements from thisFluentIterablein the order specified bycomparator. To produce anImmutableListsorted by its natural ordering, usetoSortedList(Ordering.natural()).Streamequivalent:ImmutableList.copyOf(stream.sorted(comparator).iterator()), or passImmutableList#toImmutableListtostream.sorted(comparator).collect().- Parameters:
- comparator- the function by which to sort list elements
- Throws:
- java.lang.NullPointerException- if any element of this iterable is- null
- Since:
- 14.0 (since 13.0 as toSortedImmutableList()).
 
 - 
toSetpublic final ImmutableSet<@NonNull E> toSet() Returns anImmutableSetcontaining all of the elements from this fluent iterable with duplicates removed.Streamequivalent:ImmutableSet.copyOf(stream.iterator()), or passImmutableSet#toImmutableSettostream.collect().- Throws:
- java.lang.NullPointerException- if any element is- null
- Since:
- 14.0 (since 12.0 as toImmutableSet()).
 
 - 
toSortedSetpublic final ImmutableSortedSet<@NonNull E> toSortedSet(java.util.Comparator<? super E> comparator) Returns anImmutableSortedSetcontaining all of the elements from thisFluentIterablein the order specified bycomparator, with duplicates (determined bycomparator.compare(x, y) == 0) removed. To produce anImmutableSortedSetsorted by its natural ordering, usetoSortedSet(Ordering.natural()).Streamequivalent:ImmutableSortedSet.copyOf(comparator, stream.iterator()), or passImmutableSortedSet#toImmutableSortedSettostream.collect().- Parameters:
- comparator- the function by which to sort set elements
- Throws:
- java.lang.NullPointerException- if any element of this iterable is- null
- Since:
- 14.0 (since 12.0 as toImmutableSortedSet()).
 
 - 
toMultisetpublic final ImmutableMultiset<@NonNull E> toMultiset() Returns anImmutableMultisetcontaining all of the elements from this fluent iterable.Streamequivalent:ImmutableMultiset.copyOf(stream.iterator()), or passImmutableMultiset#toImmutableMultisettostream.collect().- Throws:
- java.lang.NullPointerException- if any element is null
- Since:
- 19.0
 
 - 
toMappublic final <V> ImmutableMap<@NonNull E,V> toMap(Function<? super E,V> valueFunction) Returns an immutable map whose keys are the distinct elements of thisFluentIterableand whose value for each key was computed byvalueFunction. The map's iteration order is the order of the first appearance of each key in this iterable.When there are multiple instances of a key in this iterable, it is unspecified whether valueFunctionwill be applied to more than one instance of that key and, if it is, which result will be mapped to that key in the returned map.Streamequivalent: usestream.collect(ImmutableMap.toImmutableMap(k -> k, valueFunction)).ImmutableMap.copyOf(stream.collect(Collectors.toMap(k -> k, valueFunction)))behaves similarly, but may not preserve the order of entries.- Throws:
- java.lang.NullPointerException- if any element of this iterable is- null, or if- valueFunctionproduces- nullfor any key
- Since:
- 14.0
 
 - 
indexpublic final <K> ImmutableListMultimap<K,@NonNull E> index(Function<? super E,K> keyFunction) Creates an indexImmutableListMultimapthat contains the results of applying a specified function to each item in thisFluentIterableof values. Each element of this iterable will be stored as a value in the resulting multimap, yielding a multimap with the same size as this iterable. The key used to store that value in the multimap will be the result of calling the function on that value. The resulting multimap is created as an immutable snapshot. In the returned multimap, keys appear in the order they are first encountered, and the values corresponding to each key appear in the same order as they are encountered.Streamequivalent:stream.collect(Collectors.groupingBy(keyFunction))behaves similarly, but returns a mutableMap<K, List<E>>instead, and may not preserve the order of entries.- Parameters:
- keyFunction- the function used to produce the key for each value
- Throws:
- java.lang.NullPointerException- if any element of this iterable is- null, or if- keyFunctionproduces- nullfor any key
- Since:
- 14.0
 
 - 
uniqueIndexpublic final <K> ImmutableMap<K,@NonNull E> uniqueIndex(Function<? super E,K> keyFunction) Returns a map with the contents of thisFluentIterableas itsvalues, indexed by keys derived from those values. In other words, each input value produces an entry in the map whose key is the result of applyingkeyFunctionto that value. These entries appear in the same order as they appeared in this fluent iterable. Example usage:Color red = new Color("red", 255, 0, 0); ... FluentIterable<Color> allColors = FluentIterable.from(ImmutableSet.of(red, green, blue)); Map<String, Color> colorForName = allColors.uniqueIndex(toStringFunction()); assertThat(colorForName).containsEntry("red", red);If your index may associate multiple values with each key, use index.Streamequivalent: usestream.collect(ImmutableMap.toImmutableMap(keyFunction, v -> v)).ImmutableMap.copyOf(stream.collect(Collectors.toMap(keyFunction, v -> v))), but be aware that this may not preserve the order of entries.- Parameters:
- keyFunction- the function used to produce the key for each value
- Returns:
- a map mapping the result of evaluating the function keyFunctionon each value in this fluent iterable to that value
- Throws:
- java.lang.IllegalArgumentException- if- keyFunctionproduces the same key for more than one value in this fluent iterable
- java.lang.NullPointerException- if any element of this iterable is- null, or if- keyFunctionproduces- nullfor any key
- Since:
- 14.0
 
 - 
toArray@GwtIncompatible public final E[] toArray(java.lang.Class<@NonNull E> type) Returns an array containing all of the elements from this fluent iterable in iteration order.Streamequivalent: if an object array is acceptable, usestream.toArray(); iftypeis a class literal such asMyType.class, usestream.toArray(MyType[]::new). Otherwise usestream.toArray( len -> (E[]) Array.newInstance(type, len)).- Parameters:
- type- the type of the elements
- Returns:
- a newly-allocated array into which all the elements of this fluent iterable have been copied
 
 - 
copyInto@CanIgnoreReturnValue public final <C extends java.util.Collection<? super E>> C copyInto(C collection) Copies all the elements from this fluent iterable tocollection. This is equivalent to callingIterables.addAll(collection, this).Streamequivalent:stream.forEachOrdered(collection::add)orstream.forEach(collection::add).- Parameters:
- collection- the collection to copy elements to
- Returns:
- collection, for convenience
- Since:
- 14.0
 
 - 
joinpublic final java.lang.String join(Joiner joiner) Returns aStringcontaining all of the elements of this fluent iterable joined withjoiner.Streamequivalent:joiner.join(stream.iterator()), or, if you are not using any optionalJoinerfeatures,stream.collect(Collectors.joining(delimiter).- Since:
- 18.0
 
 - 
getpublic final E get(int position) Returns the element at the specified position in this fluent iterable.Streamequivalent:stream.skip(position).findFirst().get()(but note that this throws different exception types, and throws an exception ifnullwould be returned).- Parameters:
- position- position of the element to return
- Returns:
- the element at the specified position in this fluent iterable
- Throws:
- java.lang.IndexOutOfBoundsException- if- positionis negative or greater than or equal to the size of this fluent iterable
 
 
- 
 
-