com.google.common.collect.package-info Maven / Gradle / Ivy
Show all versions of google-collect Show documentation
/*
* Copyright (C) 2007 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* This package contains generic collection interfaces and implementations, and
* other utilities for working with collections.
*
* Collection Types
*
*
* - {@link com.google.common.collect.BiMap}
*
- An extension of {@link java.util.Map} that 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 {@linkplain com.google.common.collect.BiMap#inverse inverse view} --
* which is another instance of {@code BiMap}.
*
*
- {@link com.google.common.collect.Multiset}
*
- An extension of {@link java.util.Collection} that may contain duplicate
* values like a {@link java.util.List}, yet has order-independent equality
* like a {@link java.util.Set}. One typical use for a multiset is to
* represent a histogram.
*
*
- {@link com.google.common.collect.Multimap}
*
- A new type, which is similar to {@link java.util.Map}, but may contain
* multiple entries with the same key. Some behaviors of
* {@link com.google.common.collect.Multimap} are left unspecified and are
* provided only by the two subtypes mentioned next.
*
*
- {@link com.google.common.collect.SetMultimap}
*
- An extension of {@link com.google.common.collect.Multimap} which has
* order-independent equality and does not allow duplicate entries; that is,
* while a key may appear twice in a {@code SetMultimap}, each must map to a
* different value. {@code SetMultimap} takes its name from the fact that
* the {@linkplain com.google.common.collect.SetMultimap#get collection of
* values} associated with a fixed key fulfills the {@link java.util.Set}
* contract.
*
*
- {@link com.google.common.collect.ListMultimap}
*
- An extension of {@link com.google.common.collect.Multimap} which permits
* duplicate entries, supports random access of values for a particular key,
* and has partially order-dependent equality as defined by
* {@link com.google.common.collect.ListMultimap#equals(Object)}. {@code
* ListMultimap} takes its name from the fact that the {@linkplain
* com.google.common.collect.ListMultimap#get collection of values}
* associated with a fixed key fulfills the {@link java.util.List} contract.
*
*
- {@link com.google.common.collect.SortedSetMultimap}
*
- An extension of {@link com.google.common.collect.SetMultimap} for which
* the {@linkplain com.google.common.collect.SortedSetMultimap#get
* collection values} associated with a fixed key is a
* {@link java.util.SortedSet}.
*
*
Collection Implementations
*
* of {@link java.util.List}
*
* - {@link com.google.common.collect.ImmutableList}
*
*
*
of {@link java.util.Set}
*
* - {@link com.google.common.collect.ImmutableSet}
*
*
*
of {@link java.util.Map}
*
* - {@link com.google.common.collect.ReferenceMap}
*
*
*
of {@link com.google.common.collect.BiMap}
*
* - {@link com.google.common.collect.HashBiMap}
*
- {@link com.google.common.collect.EnumBiMap}
*
- {@link com.google.common.collect.EnumHashBiMap}
*
*
* of {@link com.google.common.collect.Multiset}
*
* - {@link com.google.common.collect.EnumMultiset}
*
- {@link com.google.common.collect.HashMultiset}
*
- {@link com.google.common.collect.LinkedHashMultiset}
*
- {@link com.google.common.collect.TreeMultiset}
*
*
* of {@link com.google.common.collect.Multimap}
*
* - {@link com.google.common.collect.ArrayListMultimap}
*
- {@link com.google.common.collect.LinkedListMultimap}
*
- {@link com.google.common.collect.HashMultimap}
*
- {@link com.google.common.collect.LinkedHashMultimap}
*
- {@link com.google.common.collect.TreeMultimap}
*
*
* Skeletal implementations
*
* - {@link com.google.common.collect.AbstractIterator}
*
- {@link com.google.common.collect.AbstractIterable}
*
- {@link com.google.common.collect.AbstractMapEntry}
*
- {@link com.google.common.collect.AbstractMultiset}
*
- {@link com.google.common.collect.AbstractMultisetEntry}
*
*
* Classes of static utility methods
*
*
* - {@link com.google.common.collect.Comparators}
*
- {@link com.google.common.collect.Iterators}
*
- {@link com.google.common.collect.Iterables}
*
- {@link com.google.common.collect.Lists}
*
- {@link com.google.common.collect.Maps}
*
- {@link com.google.common.collect.Sets}
*
- {@link com.google.common.collect.Multisets}
*
- {@link com.google.common.collect.Multimaps}
*
- {@link com.google.common.collect.ObjectArrays}
*
- {@link com.google.common.collect.PrimitiveArrays}
*
*
* Builders
*
* Constraints stuff
*
* Forwarding objects
*
*
* - {@link com.google.common.collect.ForwardingCollection }
*
- {@link com.google.common.collect.ForwardingIterator }
*
- {@link com.google.common.collect.ForwardingList }
*
- {@link com.google.common.collect.ForwardingListIterator }
*
- {@link com.google.common.collect.ForwardingMap }
*
- {@link com.google.common.collect.ForwardingMapEntry }
*
- {@link com.google.common.collect.ForwardingMultimap }
*
- {@link com.google.common.collect.ForwardingMultiset }
*
- {@link com.google.common.collect.ForwardingObject }
*
- {@link com.google.common.collect.ForwardingQueue }
*
- {@link com.google.common.collect.ForwardingSet }
*
- {@link com.google.common.collect.ForwardingSortedMap }
*
- {@link com.google.common.collect.ForwardingSortedSet }
*
*
* Common Behavior
*
* The methods of this package always throw {@link
* java.lang.NullPointerException} in response to a null value being supplied
* for any parameter that is not explicitly annotated as being {@link
* com.google.common.base.Nullable @Nullable}.
*
*
This package does not support self-containing collections: a collection
* instance that includes itself, or an object that references itself, as a
* member. Doing so may lead to undefined behavior. For example, deserialization
* can generate multiple copies of the self-containing collection. However, no
* problems will arise when a collection contains an element of the same type,
* as long as it's a different instance.
*
* @author Mike Bostock
* @author Kevin Bourrillion
* @author Jared Levy
*/
package com.google.common.collect;