Class ImmutableMap<K,V> 
- All Implemented Interfaces:
- Serializable, Map<K,- V> 
- Direct Known Subclasses:
- ImmutableBiMap, ImmutableSortedMap
Map whose contents will never change, with many other important properties detailed at
ImmutableCollection.
See the Guava User Guide article on immutable collections.
- Since:
- 2.0
- Author:
- Jesse Wilson, Kevin Bourrillion
- See Also:
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionstatic classA builder for creating immutable map instances, especiallypublic static finalmaps ("constant maps").
- 
Method SummaryModifier and TypeMethodDescriptionReturns 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.final voidclear()Deprecated.Unsupported operation.Deprecated.Unsupported operation.final VcomputeIfAbsent(K key, Function<? super K, ? extends V> mappingFunction) Deprecated.Unsupported operation.computeIfPresent(K key, BiFunction<? super K, ? super V, ? extends @Nullable V> remappingFunction) Deprecated.Unsupported operation.booleancontainsKey(@Nullable Object key) booleancontainsValue(@Nullable Object value) static <K,V> ImmutableMap <K, V> Returns an immutable map containing the specified entries.static <K,V> ImmutableMap <K, V> Returns an immutable map containing the same entries asmap.entrySet()Returns an immutable set of the mappings in this map.booleangetOrDefault(@Nullable Object key, @Nullable V defaultValue) inthashCode()booleanisEmpty()keySet()Returns an immutable set of the keys in this map, in the same order that they appear inentrySet.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.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, K k6, V v6) 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, K k6, V v6, K k7, V v7) 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, K k6, V v6, K k7, V v7, K k8, V v8) 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, K k6, V v6, K k7, V v7, K k8, V v8, K k9, V v9) 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, K k6, V v6, K k7, V v7, K k8, V v8, K k9, V v9, K k10, V v10) Returns an immutable map containing the given entries, in order.static <K,V> ImmutableMap <K, V> Returns an immutable map containing the given entries, in order.Deprecated.Unsupported operation.final voidDeprecated.Unsupported operation.putIfAbsent(K key, V value) Deprecated.Unsupported operation.Deprecated.Unsupported operation.final booleanDeprecated.Unsupported operation.Deprecated.Unsupported operation.final booleanDeprecated.Unsupported operation.final voidreplaceAll(BiFunction<? super K, ? super V, ? extends V> function) Deprecated.Unsupported operation.static <T extends @Nullable Object, K, V>
 Collector<T, ?, ImmutableMap<K, V>> toImmutableMap(Function<? super T, ? extends K> keyFunction, 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 extends @Nullable Object, K, V>
 Collector<T, ?, ImmutableMap<K, V>> toImmutableMap(Function<? super T, ? extends K> keyFunction, Function<? super T, ? extends V> valueFunction, 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.toString()values()Returns an immutable collection of the values in this map, in the same order that they appear inentrySet.
- 
Method Details- 
toImmutableMappublic static <T extends @Nullable Object, K, V> Collector<T, ?, ImmutableMap<K,V>> toImmutableMap(Function<? super T, ? extends K> keyFunction, 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
 
- 
toImmutableMappublic static <T extends @Nullable Object, K, V> Collector<T, ?, ImmutableMap<K,V>> toImmutableMap(Function<? super T, ? extends K> keyFunction, Function<? super T, ? extends V> valueFunction, 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. If the merging function returnsnull, then the collector removes the value that has been computed for the key thus far (though future occurrences of the key would reinsert it).Entries will appear in the encounter order of the first occurrence of the key. - Since:
- 21.0
 
- 
ofReturns the empty map. This map behaves and performs comparably toCollections.emptyMap(), and is preferable mainly for consistency and maintainability of your code.Performance note: the instance returned is a singleton. 
- 
ofReturns 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.
- 
ofReturns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
 
- 
ofReturns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
 
- 
ofReturns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
 
- 
ofpublic 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:
- IllegalArgumentException- if duplicate keys are provided
 
- 
ofpublic 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, K k6, V v6) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
ofpublic 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, K k6, V v6, K k7, V v7) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
ofpublic 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, K k6, V v6, K k7, V v7, K k8, V v8) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
ofpublic 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, K k6, V v6, K k7, V v7, K k8, V v8, K k9, V v9) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
ofpublic 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, K k6, V v6, K k7, V v7, K k8, V v8, K k9, V v9, K k10, V v10) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
ofEntries@SafeVarargs public static <K,V> ImmutableMap<K,V> ofEntries(Map.Entry<? extends K, ? extends V>... entries) Returns an immutable map containing the given entries, in order.- Throws:
- IllegalArgumentException- if duplicate keys are provided
- Since:
- 31.0
 
- 
builderReturns a new builder. The generated builder is equivalent to the builder created by theImmutableMap.Builderconstructor.
- 
builderWithExpectedSizeReturns 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(boolean)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
 
- 
copyOfReturns 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:
- NullPointerException- if any key or value in- mapis null
 
- 
copyOfpublic static <K,V> ImmutableMap<K,V> copyOf(Iterable<? extends 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:
- NullPointerException- if any key, value, or entry is null
- IllegalArgumentException- if two entries have the same key
- Since:
- 19.0
 
- 
putDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- putin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
putIfAbsentDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- putIfAbsentin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
replaceDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- replacein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
replaceDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- replacein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
computeIfAbsentDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- computeIfAbsentin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
computeIfPresent@Deprecated public final @Nullable V computeIfPresent(K key, BiFunction<? super K, ? super V, ? extends @Nullable V> remappingFunction) Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- computeIfPresentin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
compute@Deprecated public final @Nullable V compute(K key, BiFunction<? super K, ? super @Nullable V, ? extends @Nullable V> remappingFunction) Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- computein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
merge@Deprecated public final @Nullable V merge(K key, V value, BiFunction<? super V, ? super V, ? extends @Nullable V> function) Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- mergein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
putAllDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- putAllin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
replaceAllDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- replaceAllin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
removeDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- removein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
removeDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- removein interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
clearDeprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
- clearin interface- Map<K,- V> 
- Throws:
- UnsupportedOperationException- always
 
- 
isEmpty
- 
containsKey
- 
containsValue
- 
get
- 
getOrDefault
- 
entrySet
- 
keySet
- 
values
- 
asMultimap
- 
equals
- 
hashCode
- 
toString
 
-