Class ImmutableMap<K,V>
- java.lang.Object
-
- com.google.common.collect.ImmutableMap<K,V>
-
- All Implemented Interfaces:
java.io.Serializable,java.util.Map<K,V>
- Direct Known Subclasses:
ImmutableBiMapFauxverideShim,ImmutableMap.IteratorBasedImmutableMap,ImmutableSortedMapFauxverideShim,JdkBackedImmutableMap,RegularImmutableMap
@GwtCompatible(serializable=true, emulated=true) public abstract class ImmutableMap<K,V> extends java.lang.Object implements java.util.Map<K,V>, java.io.Serializable
AMapwhose contents will never change, with many other important properties detailed atImmutableCollection.See the Guava User Guide article on immutable collections.
- Since:
- 2.0
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classImmutableMap.Builder<K,V>A builder for creating immutable map instances, especiallypublic static finalmaps ("constant maps").(package private) static classImmutableMap.IteratorBasedImmutableMap<K,V>private classImmutableMap.MapViewOfValuesAsSingletonSets(package private) static classImmutableMap.SerializedFormSerialized type for all ImmutableMap instances.
-
Field Summary
Fields Modifier and Type Field Description (package private) static java.util.Map.Entry<?,?>[]EMPTY_ENTRY_ARRAYprivate ImmutableSet<java.util.Map.Entry<K,V>>entrySetprivate ImmutableSet<K>keySetprivate ImmutableSetMultimap<K,V>multimapViewprivate ImmutableCollection<V>values
-
Constructor Summary
Constructors Constructor Description ImmutableMap()
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description ImmutableSetMultimap<K,V>asMultimap()Returns a multimap view of the map.static <K,V>
ImmutableMap.Builder<K,V>builder()Returns a new builder.static <K,V>
ImmutableMap.Builder<K,V>builderWithExpectedSize(int expectedSize)Returns a new builder, expecting the specified number of entries to be added.(package private) static voidcheckNoConflict(boolean safe, java.lang.String conflictDescription, java.util.Map.Entry<?,?> entry1, java.util.Map.Entry<?,?> entry2)voidclear()Deprecated.Unsupported operation.Vcompute(K key, java.util.function.BiFunction<? super K,? super V,? extends V> remappingFunction)Deprecated.Unsupported operation.VcomputeIfAbsent(K key, java.util.function.Function<? super K,? extends V> mappingFunction)Deprecated.Unsupported operation.VcomputeIfPresent(K key, java.util.function.BiFunction<? super K,? super V,? extends V> remappingFunction)Deprecated.Unsupported operation.(package private) static java.lang.IllegalArgumentExceptionconflictException(java.lang.String conflictDescription, java.lang.Object entry1, java.lang.Object entry2)booleancontainsKey(java.lang.Object key)booleancontainsValue(java.lang.Object value)static <K,V>
ImmutableMap<K,V>copyOf(java.lang.Iterable<? extends java.util.Map.Entry<? extends K,? extends V>> entries)Returns an immutable map containing the specified entries.static <K,V>
ImmutableMap<K,V>copyOf(java.util.Map<? extends K,? extends V> map)Returns an immutable map containing the same entries asmap.private static <K extends java.lang.Enum<K>,V>
ImmutableMap<K,V>copyOfEnumMap(java.util.EnumMap<K,? extends V> original)(package private) abstract ImmutableSet<java.util.Map.Entry<K,V>>createEntrySet()(package private) abstract ImmutableSet<K>createKeySet()(package private) abstract ImmutableCollection<V>createValues()(package private) static <K,V>
java.util.Map.Entry<K,V>entryOf(K key, V value)Verifies thatkeyandvalueare non-null, and returns a new immutable entry with those values.ImmutableSet<java.util.Map.Entry<K,V>>entrySet()Returns an immutable set of the mappings in this map.booleanequals(java.lang.Object object)abstract Vget(java.lang.Object key)VgetOrDefault(java.lang.Object key, V defaultValue)inthashCode()booleanisEmpty()(package private) booleanisHashCodeFast()(package private) abstract booleanisPartialView()(package private) UnmodifiableIterator<K>keyIterator()ImmutableSet<K>keySet()Returns an immutable set of the keys in this map, in the same order that they appear inentrySet.(package private) java.util.Spliterator<K>keySpliterator()Vmerge(K key, V value, java.util.function.BiFunction<? super V,? super V,? extends V> remappingFunction)Deprecated.Unsupported operation.static <K,V>
ImmutableMap<K,V>of()Returns the empty map.static <K,V>
ImmutableMap<K,V>of(K k1, V v1)Returns an immutable map containing a single entry.static <K,V>
ImmutableMap<K,V>of(K k1, V v1, K k2, V v2)Returns an immutable map containing the given entries, in order.static <K,V>
ImmutableMap<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>
ImmutableMap<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>
ImmutableMap<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.Vput(K k, V v)Deprecated.Unsupported operation.voidputAll(java.util.Map<? extends K,? extends V> map)Deprecated.Unsupported operation.VputIfAbsent(K key, V value)Deprecated.Unsupported operation.Vremove(java.lang.Object o)Deprecated.Unsupported operation.booleanremove(java.lang.Object key, java.lang.Object value)Deprecated.Unsupported operation.Vreplace(K key, V value)Deprecated.Unsupported operation.booleanreplace(K key, V oldValue, V newValue)Deprecated.Unsupported operation.voidreplaceAll(java.util.function.BiFunction<? super K,? super V,? extends V> function)Deprecated.Unsupported operation.static <T,K,V>
java.util.stream.Collector<T,?,ImmutableMap<K,V>>toImmutableMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction)Returns aCollectorthat accumulates elements into anImmutableMapwhose keys and values are the result of applying the provided mapping functions to the input elements.static <T,K,V>
java.util.stream.Collector<T,?,ImmutableMap<K,V>>toImmutableMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction, java.util.function.BinaryOperator<V> mergeFunction)Returns aCollectorthat accumulates elements into anImmutableMapwhose keys and values are the result of applying the provided mapping functions to the input elements.java.lang.StringtoString()ImmutableCollection<V>values()Returns an immutable collection of the values in this map, in the same order that they appear inentrySet.(package private) java.lang.ObjectwriteReplace()
-
-
-
Field Detail
-
EMPTY_ENTRY_ARRAY
static final java.util.Map.Entry<?,?>[] EMPTY_ENTRY_ARRAY
-
entrySet
private transient ImmutableSet<java.util.Map.Entry<K,V>> entrySet
-
keySet
private transient ImmutableSet<K> keySet
-
values
private transient ImmutableCollection<V> values
-
multimapView
private transient ImmutableSetMultimap<K,V> multimapView
-
-
Method Detail
-
toImmutableMap
public static <T,K,V> java.util.stream.Collector<T,?,ImmutableMap<K,V>> toImmutableMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction)
Returns aCollectorthat accumulates elements into anImmutableMapwhose keys and values are the result of applying the provided mapping functions to the input elements. Entries appear in the resultImmutableMapin encounter order.If the mapped keys 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
-
toImmutableMap
public static <T,K,V> java.util.stream.Collector<T,?,ImmutableMap<K,V>> toImmutableMap(java.util.function.Function<? super T,? extends K> keyFunction, java.util.function.Function<? super T,? extends V> valueFunction, java.util.function.BinaryOperator<V> mergeFunction)
Returns aCollectorthat accumulates elements into anImmutableMapwhose keys and values are the result of applying the provided mapping functions to the input elements.If the mapped keys contain duplicates (according to
Object.equals(Object)), the values are merged using the specified merging function. Entries will appear in the encounter order of the first occurrence of the key.- Since:
- 21.0
-
of
public static <K,V> ImmutableMap<K,V> of()
Returns the empty map. This map behaves and performs comparably toCollections.emptyMap(), and is preferable mainly for consistency and maintainability of your code.
-
of
public static <K,V> ImmutableMap<K,V> of(K k1, V v1)
Returns an immutable map containing a single entry. This map behaves and performs comparably toCollections.singletonMap(K, V)but will not accept a null key or value. It is preferable mainly for consistency and maintainability of your code.
-
of
public static <K,V> ImmutableMap<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 are provided
-
of
public static <K,V> ImmutableMap<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 are provided
-
of
public static <K,V> ImmutableMap<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 are provided
-
of
public static <K,V> ImmutableMap<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 are provided
-
entryOf
static <K,V> java.util.Map.Entry<K,V> entryOf(K key, V value)Verifies thatkeyandvalueare non-null, and returns a new immutable entry with those values.A call to
Map.Entry.setValue(V)on the returned entry will always throwUnsupportedOperationException.
-
builder
public static <K,V> ImmutableMap.Builder<K,V> builder()
Returns a new builder. The generated builder is equivalent to the builder created by theImmutableMap.Builderconstructor.
-
builderWithExpectedSize
@Beta public static <K,V> ImmutableMap.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 beforeImmutableMap.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
-
checkNoConflict
static void checkNoConflict(boolean safe, java.lang.String conflictDescription, java.util.Map.Entry<?,?> entry1, java.util.Map.Entry<?,?> entry2)
-
conflictException
static java.lang.IllegalArgumentException conflictException(java.lang.String conflictDescription, java.lang.Object entry1, java.lang.Object entry2)
-
copyOf
public static <K,V> ImmutableMap<K,V> copyOf(java.util.Map<? extends K,? extends V> map)
Returns an immutable map containing the same entries asmap. The returned map iterates over entries in the same order as theentrySetof the original map. 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.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.NullPointerException- if any key or value inmapis null
-
copyOf
@Beta public static <K,V> ImmutableMap<K,V> copyOf(java.lang.Iterable<? extends java.util.Map.Entry<? extends K,? extends V>> entries)
Returns an immutable map containing the specified entries. The returned map iterates over entries in the same order as the original iterable.- Throws:
java.lang.NullPointerException- if any key, value, or entry is nulljava.lang.IllegalArgumentException- if two entries have the same key- Since:
- 19.0
-
copyOfEnumMap
private static <K extends java.lang.Enum<K>,V> ImmutableMap<K,V> copyOfEnumMap(java.util.EnumMap<K,? extends V> original)
-
put
@Deprecated public final V put(K k, V v)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
putIfAbsent
@Deprecated public final V putIfAbsent(K key, V value)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
replace
@Deprecated public final boolean replace(K key, V oldValue, V newValue)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
replace
@Deprecated public final V replace(K key, V value)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
computeIfAbsent
@Deprecated public final V computeIfAbsent(K key, java.util.function.Function<? super K,? extends V> mappingFunction)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
computeIfPresent
@Deprecated public final V computeIfPresent(K key, java.util.function.BiFunction<? super K,? super V,? extends V> remappingFunction)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
compute
@Deprecated public final V compute(K key, java.util.function.BiFunction<? super K,? super V,? extends V> remappingFunction)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
merge
@Deprecated public final V merge(K key, V value, java.util.function.BiFunction<? super V,? super V,? extends V> remappingFunction)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
putAll
@Deprecated public final void putAll(java.util.Map<? extends K,? extends V> map)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
replaceAll
@Deprecated public final void replaceAll(java.util.function.BiFunction<? super K,? super V,? extends V> function)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
remove
@Deprecated public final V remove(java.lang.Object o)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
remove
@Deprecated public final boolean remove(java.lang.Object key, java.lang.Object value)Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
clear
@Deprecated public final void clear()
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.
-
containsKey
public boolean containsKey(java.lang.Object key)
-
containsValue
public boolean containsValue(java.lang.Object value)
-
entrySet
public ImmutableSet<java.util.Map.Entry<K,V>> entrySet()
Returns an immutable set of the mappings in this map. The iteration order is specified by the method used to create this map. Typically, this is insertion order.
-
createEntrySet
abstract ImmutableSet<java.util.Map.Entry<K,V>> createEntrySet()
-
keySet
public ImmutableSet<K> keySet()
Returns an immutable set of the keys in this map, in the same order that they appear inentrySet.
-
createKeySet
abstract ImmutableSet<K> createKeySet()
-
keyIterator
UnmodifiableIterator<K> keyIterator()
-
keySpliterator
java.util.Spliterator<K> keySpliterator()
-
values
public ImmutableCollection<V> values()
Returns an immutable collection of the values in this map, in the same order that they appear inentrySet.
-
createValues
abstract ImmutableCollection<V> createValues()
-
asMultimap
public ImmutableSetMultimap<K,V> asMultimap()
Returns a multimap view of the map.- Since:
- 14.0
-
equals
public boolean equals(java.lang.Object object)
-
isPartialView
abstract boolean isPartialView()
-
hashCode
public int hashCode()
-
isHashCodeFast
boolean isHashCodeFast()
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
writeReplace
java.lang.Object writeReplace()
-
-