Class ImmutableBiMap<K,V>
- java.lang.Object
-
- com.google.common.collect.ImmutableMap<K,V>
-
- com.google.common.collect.ImmutableBiMapFauxverideShim<K,V>
-
- com.google.common.collect.ImmutableBiMap<K,V>
-
- All Implemented Interfaces:
BiMap<K,V>,java.io.Serializable,java.util.Map<K,V>
- Direct Known Subclasses:
JdkBackedImmutableBiMap,RegularImmutableBiMap,RegularImmutableBiMap.Inverse,SingletonImmutableBiMap
@GwtCompatible(serializable=true, emulated=true) public abstract class ImmutableBiMap<K,V> extends ImmutableBiMapFauxverideShim<K,V> implements BiMap<K,V>
ABiMapwhose contents will never change, with many other important properties detailed atImmutableCollection.- Since:
- 2.0
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classImmutableBiMap.Builder<K,V>A builder for creating immutable bimap instances, especiallypublic static finalbimaps ("constant bimaps").private static classImmutableBiMap.SerializedFormSerialized type for all ImmutableBiMap instances.-
Nested classes/interfaces inherited from class com.google.common.collect.ImmutableMap
ImmutableMap.IteratorBasedImmutableMap<K,V>
-
-
Field Summary
-
Fields inherited from class com.google.common.collect.ImmutableMap
EMPTY_ENTRY_ARRAY
-
-
Constructor Summary
Constructors Constructor Description ImmutableBiMap()
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description static <K,V>
ImmutableBiMap.Builder<K,V>builder()Returns a new builder.static <K,V>
ImmutableBiMap.Builder<K,V>builderWithExpectedSize(int expectedSize)Returns a new builder, expecting the specified number of entries to be added.static <K,V>
ImmutableBiMap<K,V>copyOf(java.lang.Iterable<? extends java.util.Map.Entry<? extends K,? extends V>> entries)Returns an immutable bimap containing the given entries.static <K,V>
ImmutableBiMap<K,V>copyOf(java.util.Map<? extends K,? extends V> map)Returns an immutable bimap containing the same entries asmap.(package private) ImmutableSet<V>createValues()VforcePut(K key, V value)Deprecated.Unsupported operation.abstract ImmutableBiMap<V,K>inverse()Returns the inverse view of this bimap, which maps each of this bimap's values to its associated key.static <K,V>
ImmutableBiMap<K,V>of()Returns the empty bimap.static <K,V>
ImmutableBiMap<K,V>of(K k1, V v1)Returns an immutable bimap containing a single entry.static <K,V>
ImmutableBiMap<K,V>of(K k1, V v1, K k2, V v2)Returns an immutable map containing the given entries, in order.static <K,V>
ImmutableBiMap<K,V>of(K k1, V v1, K k2, V v2, K k3, V v3)Returns an immutable map containing the given entries, in order.static <K,V>
ImmutableBiMap<K,V>of(K k1, V v1, K k2, V v2, K k3, V v3, K k4, V v4)Returns an immutable map containing the given entries, in order.static <K,V>
ImmutableBiMap<K,V>of(K k1, V v1, K k2, V v2, K k3, V v3, K k4, V v4, K k5, V v5)Returns an immutable map containing the given entries, in order.static <T,K,V>
java.util.stream.Collector<T,?,ImmutableBiMap<K,V>>toImmutableBiMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction)Returns aCollectorthat accumulates elements into anImmutableBiMapwhose keys and values are the result of applying the provided mapping functions to the input elements.ImmutableSet<V>values()Returns an immutable set of the values in this map, in the same order they appear inImmutableMap.entrySet.(package private) java.lang.ObjectwriteReplace()-
Methods inherited from class com.google.common.collect.ImmutableBiMapFauxverideShim
toImmutableMap, toImmutableMap
-
Methods inherited from class com.google.common.collect.ImmutableMap
asMultimap, checkNoConflict, clear, compute, computeIfAbsent, computeIfPresent, conflictException, containsKey, containsValue, createEntrySet, createKeySet, entryOf, entrySet, equals, get, getOrDefault, hashCode, isEmpty, isHashCodeFast, isPartialView, keyIterator, keySet, keySpliterator, merge, put, putAll, putIfAbsent, remove, remove, replace, replace, replaceAll, toString
-
-
-
-
Method Detail
-
toImmutableBiMap
public static <T,K,V> java.util.stream.Collector<T,?,ImmutableBiMap<K,V>> toImmutableBiMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction)
Returns aCollectorthat accumulates elements into anImmutableBiMapwhose keys and values are the result of applying the provided mapping functions to the input elements. Entries appear in the resultImmutableBiMapin encounter order.If the mapped keys or values contain duplicates (according to
Object.equals(Object), anIllegalArgumentExceptionis thrown when the collection operation is performed. (This differs from theCollectorreturned byCollectors.toMap(Function, Function), which throws anIllegalStateException.)- Since:
- 21.0
-
of
public static <K,V> ImmutableBiMap<K,V> of()
Returns the empty bimap.
-
of
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1)
Returns an immutable bimap containing a single entry.
-
of
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2)
Returns an immutable map containing the given entries, in order.- Throws:
java.lang.IllegalArgumentException- if duplicate keys or values are added
-
of
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2, K k3, V v3)
Returns an immutable map containing the given entries, in order.- Throws:
java.lang.IllegalArgumentException- if duplicate keys or values are added
-
of
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2, K k3, V v3, K k4, V v4)
Returns an immutable map containing the given entries, in order.- Throws:
java.lang.IllegalArgumentException- if duplicate keys or values are added
-
of
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2, K k3, V v3, K k4, V v4, K k5, V v5)
Returns an immutable map containing the given entries, in order.- Throws:
java.lang.IllegalArgumentException- if duplicate keys or values are added
-
builder
public static <K,V> ImmutableBiMap.Builder<K,V> builder()
Returns a new builder. The generated builder is equivalent to the builder created by theImmutableBiMap.Builderconstructor.
-
builderWithExpectedSize
@Beta public static <K,V> ImmutableBiMap.Builder<K,V> builderWithExpectedSize(int expectedSize)
Returns a new builder, expecting the specified number of entries to be added.If
expectedSizeis exactly the number of entries added to the builder beforeImmutableBiMap.Builder.build()is called, the builder is likely to perform better than an unsizedbuilder()would have.It is not specified if any performance benefits apply if
expectedSizeis close to, but not exactly, the number of entries added to the builder.- Since:
- 23.1
-
copyOf
public static <K,V> ImmutableBiMap<K,V> copyOf(java.util.Map<? extends K,? extends V> map)
Returns an immutable bimap containing the same entries asmap. Ifmapsomehow contains entries with duplicate keys (for example, if it is aSortedMapwhose comparator is not consistent with equals), the results of this method are undefined.The returned
BiMapiterates over entries in the same order as theentrySetof the original map.Despite the method name, this method attempts to avoid actually copying the data when it is safe to do so. The exact circumstances under which a copy will or will not be performed are undocumented and subject to change.
- Throws:
java.lang.IllegalArgumentException- if two keys have the same value or two values have the same keyjava.lang.NullPointerException- if any key or value inmapis null
-
copyOf
@Beta public static <K,V> ImmutableBiMap<K,V> copyOf(java.lang.Iterable<? extends java.util.Map.Entry<? extends K,? extends V>> entries)
Returns an immutable bimap containing the given entries. The returned bimap iterates over entries in the same order as the original iterable.- Throws:
java.lang.IllegalArgumentException- if two keys have the same value or two values have the same keyjava.lang.NullPointerException- if any key, value, or entry is null- Since:
- 19.0
-
inverse
public abstract ImmutableBiMap<V,K> inverse()
Returns the inverse view of this bimap, which maps each of this bimap's values to its associated key. The two bimaps are backed by the same data; any changes to one will appear in the other.Note:There is no guaranteed correspondence between the iteration order of a bimap and that of its inverse.
The inverse of an
ImmutableBiMapis anotherImmutableBiMap.
-
values
public ImmutableSet<V> values()
Returns an immutable set of the values in this map, in the same order they appear inImmutableMap.entrySet.
-
createValues
final ImmutableSet<V> createValues()
- Specified by:
createValuesin classImmutableMap<K,V>
-
forcePut
@Deprecated public V forcePut(K key, V value)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the bimap unmodified.- Specified by:
forcePutin interfaceBiMap<K,V>- Parameters:
key- the key with which the specified value is to be associatedvalue- the value to be associated with the specified key- Returns:
- the value which was previously associated with the key, which may be
null, ornullif there was no previous entry - Throws:
java.lang.UnsupportedOperationException- always
-
writeReplace
java.lang.Object writeReplace()
- Overrides:
writeReplacein classImmutableMap<K,V>
-
-