@CheckReturnValue @ParametersAreNonnullByDefault
Package com.google.common.collect
This package contains generic collection interfaces and implementations, and other utilities for
working with collections. It is a part of the open-source Guava library.
of
of
of
of
of
of
of
of
Collection Types
BiMap- An extension of
Mapthat guarantees the uniqueness of its values as well as that of its keys. This is sometimes called an "invertible map," since the restriction on values enables it to support an inverse view -- which is another instance ofBiMap. Multiset- An extension of
Collectionthat may contain duplicate values like aList, yet has order-independent equality like aSet. One typical use for a multiset is to represent a histogram. Multimap- A new type, which is similar to
Map, but may contain multiple entries with the same key. Some behaviors ofMultimapare left unspecified and are provided only by the subtypes mentioned below. ListMultimap- An extension of
Multimapwhich permits duplicate entries, supports random access of values for a particular key, and has partially order-dependent equality as defined byListMultimap.equals(Object).ListMultimaptakes its name from the fact that the collection of values associated with a given key fulfills theListcontract. SetMultimap- An extension of
Multimapwhich has order-independent equality and does not allow duplicate entries; that is, while a key may appear twice in aSetMultimap, each must map to a different value.SetMultimaptakes its name from the fact that the collection of values associated with a given key fulfills theSetcontract. SortedSetMultimap- An extension of
SetMultimapfor which the collection values associated with a given key is aSortedSet. Table- A new type, which is similar to
Map, but which indexes its values by an ordered pair of keys, a row key and column key. ClassToInstanceMap- An extension of
Mapthat associates a raw type with an instance of that type.
Collection Implementations
of List
of Set
ImmutableSetImmutableSortedSetContiguousSet(seeRange)
of Map
of BiMap
of Multiset
ImmutableMultisetImmutableSortedMultisetHashMultisetLinkedHashMultisetTreeMultisetEnumMultisetConcurrentHashMultiset
of Multimap
ImmutableMultimapImmutableListMultimapImmutableSetMultimapArrayListMultimapHashMultimapTreeMultimapLinkedHashMultimapLinkedListMultimap
of Table
of ClassToInstanceMap
Classes of static utility methods
Comparison
Abstract implementations
AbstractIteratorAbstractSequentialIteratorImmutableCollectionUnmodifiableIteratorUnmodifiableListIterator
Ranges
Other
Forwarding collections
ForwardingCollectionForwardingConcurrentMapForwardingIteratorForwardingListForwardingListIteratorForwardingListMultimapForwardingMapForwardingMapEntryForwardingMultimapForwardingMultisetForwardingNavigableMapForwardingNavigableSetForwardingObjectForwardingQueueForwardingSetForwardingSetMultimapForwardingSortedMapForwardingSortedMultisetForwardingSortedSetForwardingSortedSetMultimapForwardingTable
-
Interface Summary Interface Description BiMap<K extends @Nullable Object,V extends @Nullable Object> A bimap (or "bidirectional map") is a map that preserves the uniqueness of its values as well as that of its keys.ClassToInstanceMap<B> A map, each entry of which maps a Java raw type to an instance of that type.Interner<E> Provides similar behavior toString.intern()for any immutable type.ListMultimap<K extends @Nullable Object,V extends @Nullable Object> AMultimapthat can hold duplicate key-value pairs and that maintains the insertion ordering of values for a given key.MapDifference<K extends @Nullable Object,V extends @Nullable Object> An object representing the differences between two maps.MapDifference.ValueDifference<V extends @Nullable Object> A difference between the mappings from two maps with the same key.Maps.EntryTransformer<K extends @Nullable Object,V1 extends @Nullable Object,V2 extends @Nullable Object> A transformation of the value of a key-value pair, using both key and value as inputs.Multimap<K extends @Nullable Object,V extends @Nullable Object> A collection that maps keys to values, similar toMap, but in which each key may be associated with multiple values.Multiset<E extends @Nullable Object> A collection that supports order-independent equality, likeSet, but may have duplicate elements.Multiset.Entry<E extends @Nullable Object> An unmodifiable element-count pair for a multiset.PeekingIterator<E extends @Nullable Object> An iterator that supports a one-element lookahead while iterating.RangeMap<K extends Comparable,V> A mapping from disjoint nonempty ranges to non-null values.RangeSet<C extends Comparable> RowSortedTable<R extends @Nullable Object,C extends @Nullable Object,V extends @Nullable Object> Interface that extendsTableand whose rows are sorted.SetMultimap<K extends @Nullable Object,V extends @Nullable Object> AMultimapthat cannot hold duplicate key-value pairs.SortedMapDifference<K extends @Nullable Object,V extends @Nullable Object> An object representing the differences between two sorted maps.SortedMultiset<E extends @Nullable Object> AMultisetwhich maintains the ordering of its elements, according to either their natural order or an explicitComparator.SortedSetMultimap<K extends @Nullable Object,V extends @Nullable Object> ASetMultimapwhose set of values for a given key are kept sorted; that is, they comprise aSortedSet.Streams.DoubleFunctionWithIndex<R extends @Nullable Object> An analogue ofDoubleFunctionalso accepting an index.Streams.FunctionWithIndex<T extends @Nullable Object,R extends @Nullable Object> An analogue ofFunctionalso accepting an index.Streams.IntFunctionWithIndex<R extends @Nullable Object> An analogue ofIntFunctionalso accepting an index.Streams.LongFunctionWithIndex<R extends @Nullable Object> An analogue ofLongFunctionalso accepting an index.Table<R extends @Nullable Object,C extends @Nullable Object,V extends @Nullable Object> A collection that associates an ordered pair of keys, called a row key and a column key, with a single value.Table.Cell<R extends @Nullable Object,C extends @Nullable Object,V extends @Nullable Object> Row key / column key / value triplet corresponding to a mapping in a table. -
Class Summary Class Description AbstractIterator<T extends @Nullable Object> This class provides a skeletal implementation of theIteratorinterface, to make this interface easier to implement for certain types of data sources.AbstractSequentialIterator<T> This class provides a skeletal implementation of theIteratorinterface for sequences whose next element can always be derived from the previous element.ArrayListMultimap<K extends @Nullable Object,V extends @Nullable Object> Implementation ofMultimapthat uses anArrayListto store the values for a given key.ArrayTable<R,C,V> Fixed-sizeTableimplementation backed by a two-dimensional array.Collections2 Provides static methods for working withCollectioninstances.Comparators Provides static methods for working withComparatorinstances.ComparisonChain A utility for performing a chained comparison statement.ConcurrentHashMultiset<E> A multiset that supports concurrent modifications and that provides atomic versions of mostMultisetoperations (exceptions where noted).ContiguousSet<C extends Comparable> A sorted set of contiguous values in a givenDiscreteDomain.DiscreteDomain<C extends Comparable> A descriptor for a discreteComparabledomain such as allIntegerinstances.EnumBiMap<K extends Enum<K>,V extends Enum<V>> ABiMapbacked by twoEnumMapinstances.EnumHashBiMap<K extends Enum<K>,V extends @Nullable Object> ABiMapbacked by anEnumMapinstance for keys-to-values, and aHashMapinstance for values-to-keys.EnumMultiset<E extends Enum<E>> Multiset implementation specialized for enum elements, supporting all single-element operations in O(1).EvictingQueue<E> A non-blocking queue which automatically evicts elements from the head of the queue when attempting to add new elements onto the queue and it is full.FluentIterable<E extends @Nullable Object> A discouraged (but not deprecated) precursor to Java's superiorStreamlibrary.ForwardingBlockingDeque<E> Deprecated. This class has moved tocom.google.common.util.concurrent.ForwardingCollection<E extends @Nullable Object> A collection which forwards all its method calls to another collection.ForwardingConcurrentMap<K,V> A concurrent map which forwards all its method calls to another concurrent map.ForwardingDeque<E extends @Nullable Object> A deque which forwards all its method calls to another deque.ForwardingIterator<T extends @Nullable Object> An iterator which forwards all its method calls to another iterator.ForwardingList<E extends @Nullable Object> A list which forwards all its method calls to another list.ForwardingListIterator<E extends @Nullable Object> A list iterator which forwards all its method calls to another list iterator.ForwardingListMultimap<K extends @Nullable Object,V extends @Nullable Object> A list multimap which forwards all its method calls to another list multimap.ForwardingMap<K extends @Nullable Object,V extends @Nullable Object> A map which forwards all its method calls to another map.ForwardingMapEntry<K extends @Nullable Object,V extends @Nullable Object> A map entry which forwards all its method calls to another map entry.ForwardingMultimap<K extends @Nullable Object,V extends @Nullable Object> A multimap which forwards all its method calls to another multimap.ForwardingMultiset<E extends @Nullable Object> A multiset which forwards all its method calls to another multiset.ForwardingNavigableMap<K extends @Nullable Object,V extends @Nullable Object> A navigable map which forwards all its method calls to another navigable map.ForwardingNavigableSet<E extends @Nullable Object> A navigable set which forwards all its method calls to another navigable set.ForwardingObject An abstract base class for implementing the decorator pattern.ForwardingQueue<E extends @Nullable Object> A queue which forwards all its method calls to another queue.ForwardingSet<E extends @Nullable Object> A set which forwards all its method calls to another set.ForwardingSetMultimap<K extends @Nullable Object,V extends @Nullable Object> A set multimap which forwards all its method calls to another set multimap.ForwardingSortedMap<K extends @Nullable Object,V extends @Nullable Object> A sorted map which forwards all its method calls to another sorted map.ForwardingSortedMultiset<E extends @Nullable Object> A sorted multiset which forwards all its method calls to another sorted multiset.ForwardingSortedSet<E extends @Nullable Object> A sorted set which forwards all its method calls to another sorted set.ForwardingSortedSetMultimap<K extends @Nullable Object,V extends @Nullable Object> A sorted set multimap which forwards all its method calls to another sorted set multimap.ForwardingTable<R extends @Nullable Object,C extends @Nullable Object,V extends @Nullable Object> A table which forwards all its method calls to another table.HashBasedTable<R,C,V> Implementation ofTableusing linked hash tables.HashBiMap<K extends @Nullable Object,V extends @Nullable Object> ABiMapbacked by two hash tables.HashMultimap<K extends @Nullable Object,V extends @Nullable Object> Implementation ofMultimapusing hash tables.HashMultiset<E extends @Nullable Object> Multiset implementation backed by aHashMap.ImmutableBiMap<K,V> ABiMapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableBiMap.Builder<K,V> A builder for creating immutable bimap instances, especiallypublic static finalbimaps ("constant bimaps").ImmutableClassToInstanceMap<B> AClassToInstanceMapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableClassToInstanceMap.Builder<B> A builder for creating immutable class-to-instance maps.ImmutableCollection<E> ACollectionwhose contents will never change, and which offers a few additional guarantees detailed below.ImmutableCollection.Builder<E> Abstract base class for builders ofImmutableCollectiontypes.ImmutableList<E> AListwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableList.Builder<E> A builder for creating immutable list instances, especiallypublic static finallists ("constant lists").ImmutableListMultimap<K,V> AListMultimapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableListMultimap.Builder<K,V> A builder for creating immutableListMultimapinstances, especiallypublic static finalmultimaps ("constant multimaps").ImmutableMap<K,V> AMapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableMap.Builder<K,V> A builder for creating immutable map instances, especiallypublic static finalmaps ("constant maps").ImmutableMultimap<K,V> AMultimapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableMultimap.Builder<K,V> A builder for creating immutable multimap instances, especiallypublic static finalmultimaps ("constant multimaps").ImmutableMultiset<E> AMultisetwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableMultiset.Builder<E> A builder for creating immutable multiset instances, especiallypublic static finalmultisets ("constant multisets").ImmutableRangeMap<K extends Comparable<?>,V> ARangeMapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableRangeMap.Builder<K extends Comparable<?>,V> A builder for immutable range maps.ImmutableRangeSet<C extends Comparable> ARangeSetwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableRangeSet.Builder<C extends Comparable<?>> A builder for immutable range sets.ImmutableSet<E> ASetwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableSet.Builder<E> A builder for creatingImmutableSetinstances.ImmutableSetMultimap<K,V> ASetMultimapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableSetMultimap.Builder<K,V> A builder for creating immutableSetMultimapinstances, especiallypublic static finalmultimaps ("constant multimaps").ImmutableSortedMap<K,V> ANavigableMapwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableSortedMap.Builder<K,V> A builder for creating immutable sorted map instances, especiallypublic static finalmaps ("constant maps").ImmutableSortedMultiset<E> ASortedMultisetwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableSortedMultiset.Builder<E> A builder for creating immutable multiset instances, especiallypublic static finalmultisets ("constant multisets").ImmutableSortedSet<E> ANavigableSetwhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableSortedSet.Builder<E> A builder for creating immutable sorted set instances, especiallypublic static finalsets ("constant sets"), with a given comparator.ImmutableTable<R,C,V> ATablewhose contents will never change, with many other important properties detailed atImmutableCollection.ImmutableTable.Builder<R,C,V> A builder for creating immutable table instances, especiallypublic static finaltables ("constant tables").Interners Contains static methods pertaining to instances ofInterner.Interners.InternerBuilder Builder forInternerinstances.Iterables An assortment of mainly legacy static utility methods that operate on or return objects of typeIterable.Iterators This class contains static utility methods that operate on or return objects of typeIterator.LinkedHashMultimap<K extends @Nullable Object,V extends @Nullable Object> Implementation ofMultimapthat does not allow duplicate key-value entries and that returns collections whose iterators follow the ordering in which the data was added to the multimap.LinkedHashMultiset<E extends @Nullable Object> AMultisetimplementation with predictable iteration order.LinkedListMultimap<K extends @Nullable Object,V extends @Nullable Object> An implementation ofListMultimapthat supports deterministic iteration order for both keys and values.Lists Static utility methods pertaining toListinstances.MapMaker A builder ofConcurrentMapinstances that can have keys or values automatically wrapped in weak references.Maps MinMaxPriorityQueue<E> A double-ended priority queue, which provides constant-time access to both its least element and its greatest element, as determined by the queue's specified comparator.MinMaxPriorityQueue.Builder<B> The builder class used in creation of min-max priority queues.MoreCollectors Collectors not present injava.util.stream.Collectorsthat are not otherwise associated with acom.google.commontype.MultimapBuilder<K0 extends @Nullable Object,V0 extends @Nullable Object> A builder for a multimap implementation that allows customization of the backing map and value collection implementations used in a particular multimap.MultimapBuilder.ListMultimapBuilder<K0 extends @Nullable Object,V0 extends @Nullable Object> A specialization ofMultimapBuilderthat generatesListMultimapinstances.MultimapBuilder.MultimapBuilderWithKeys<K0 extends @Nullable Object> An intermediate stage in aMultimapBuilderin which the key-value collection map implementation has been specified, but the value collection implementation has not.MultimapBuilder.SetMultimapBuilder<K0 extends @Nullable Object,V0 extends @Nullable Object> A specialization ofMultimapBuilderthat generatesSetMultimapinstances.MultimapBuilder.SortedSetMultimapBuilder<K0 extends @Nullable Object,V0 extends @Nullable Object> A specialization ofMultimapBuilderthat generatesSortedSetMultimapinstances.Multimaps Provides static methods acting on or generating aMultimap.Multisets Provides static utility methods for creating and working withMultisetinstances.MutableClassToInstanceMap<B> A mutable class-to-instance map backed by an arbitrary user-provided map.ObjectArrays Static utility methods pertaining to object arrays.Ordering<T extends @Nullable Object> A comparator, with additional methods to support common operations.Queues Range<C extends Comparable> A range (or "interval") defines the boundaries around a contiguous span of values of someComparabletype; for example, "integers from 1 to 100 inclusive." Note that it is not possible to iterate over these contained values.Sets Static utility methods pertaining toSetinstances.Sets.SetView<E extends @Nullable Object> An unmodifiable view of a set which may be backed by other sets; this view will change as the backing sets do.Streams Static utility methods related toStreaminstances.Tables Provides static methods that involve aTable.TreeBasedTable<R,C,V> Implementation ofTablewhose row keys and column keys are ordered by their natural ordering or by supplied comparators.TreeMultimap<K extends @Nullable Object,V extends @Nullable Object> Implementation ofMultimapwhose keys and values are ordered by their natural ordering or by supplied comparators.TreeMultiset<E extends @Nullable Object> A multiset which maintains the ordering of its elements, according to either their natural order or an explicitComparator.TreeRangeMap<K extends Comparable,V> An implementation ofRangeMapbased on aTreeMap, supporting all optional operations.TreeRangeSet<C extends Comparable<?>> TreeTraverser<T> Deprecated. UseTraverserinstead.UnmodifiableIterator<E extends @Nullable Object> An iterator that does not supportUnmodifiableIterator.remove().UnmodifiableListIterator<E extends @Nullable Object> A list iterator that does not supportUnmodifiableIterator.remove(),UnmodifiableListIterator.add(E), orUnmodifiableListIterator.set(E). -
Enum Summary Enum Description BoundType Indicates whether an endpoint of some range is contained in the range itself ("closed") or not ("open"). -
Exception Summary Exception Description ComputationException Deprecated. This exception is no longer thrown bycom.google.common.