Class ImmutableMap<K,V>
- java.lang.Object
-
- com.google.common.collect.ImmutableMap<K,V>
-
- All Implemented Interfaces:
Serializable
,Map<K,V>
- Direct Known Subclasses:
ImmutableBiMap
,ImmutableSortedMap
@DoNotMock("Use ImmutableMap.of or another implementation") @GwtCompatible(serializable=true, emulated=true) public abstract class ImmutableMap<K,V> extends Object implements Map<K,V>, Serializable
AMap
whose contents will never change, with many other important properties detailed atImmutableCollection
.See the Guava User Guide article on immutable collections.
- Since:
- 2.0
- Author:
- Jesse Wilson, Kevin Bourrillion
- See Also:
- Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
ImmutableMap.Builder<K,V>
A builder for creating immutable map instances, especiallypublic static final
maps ("constant maps").
-
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.void
clear()
Deprecated.Unsupported operation.boolean
containsKey(Object key)
boolean
containsValue(Object value)
static <K,V>
ImmutableMap<K,V>copyOf(Iterable<? extends Map.Entry<? extends K,? extends V>> entries)
Returns an immutable map containing the specified entries.static <K,V>
ImmutableMap<K,V>copyOf(Map<? extends K,? extends V> map)
Returns an immutable map containing the same entries asmap
.ImmutableSet<Map.Entry<K,V>>
entrySet()
Returns an immutable set of the mappings in this map.boolean
equals(Object object)
abstract V
get(Object key)
V
getOrDefault(Object key, V defaultValue)
int
hashCode()
boolean
isEmpty()
ImmutableSet<K>
keySet()
Returns an immutable set of the keys in this map, in the same order that they appear inentrySet
.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>ofEntries(Map.Entry<? extends K,? extends V>... entries)
Returns an immutable map containing the given entries, in order.V
put(K k, V v)
Deprecated.Unsupported operation.void
putAll(Map<? extends K,? extends V> map)
Deprecated.Unsupported operation.V
remove(Object o)
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 aCollector
that accumulates elements into anImmutableMap
whose 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 aCollector
that accumulates elements into anImmutableMap
whose keys and values are the result of applying the provided mapping functions to the input elements.String
toString()
ImmutableCollection<V>
values()
Returns an immutable collection of the values in this map, in the same order that they appear inentrySet
.-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, forEach, merge, putIfAbsent, remove, replace, replace, replaceAll, size
-
-
-
-
Method Detail
-
toImmutableMap
public 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 aCollector
that accumulates elements into anImmutableMap
whose keys and values are the result of applying the provided mapping functions to the input elements. Entries appear in the resultImmutableMap
in encounter order.If the mapped keys contain duplicates (according to
Object.equals(Object)
, anIllegalArgumentException
is thrown when the collection operation is performed. (This differs from theCollector
returned byCollectors.toMap(Function, Function)
, which throws anIllegalStateException
.)- Since:
- 33.2.0 (available since 21.0 in guava-jre)
-
toImmutableMap
public 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 aCollector
that accumulates elements into anImmutableMap
whose 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:
- 33.2.0 (available since 21.0 in guava-jre)
-
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.Performance note: the instance returned is a singleton.
-
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:
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:
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:
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:
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, K k6, V v6)
Returns an immutable map containing the given entries, in order.- Throws:
IllegalArgumentException
- if duplicate keys are provided- Since:
- 31.0
-
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, 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
-
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, 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
-
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, 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
-
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, 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
-
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.Builder
constructor.
-
builderWithExpectedSize
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
expectedSize
is 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
expectedSize
is close to, but not exactly, the number of entries added to the builder.- Since:
- 23.1
-
copyOf
public static <K,V> ImmutableMap<K,V> copyOf(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 theentrySet
of the original map. Ifmap
somehow contains entries with duplicate keys (for example, if it is aSortedMap
whose 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 inmap
is null
-
copyOf
public 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 nullIllegalArgumentException
- if two entries have the same key- Since:
- 19.0
-
put
@CanIgnoreReturnValue @Deprecated @CheckForNull public final V put(K k, V v)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
put
in interfaceMap<K,V>
- Throws:
UnsupportedOperationException
- always
-
remove
@CanIgnoreReturnValue @Deprecated @CheckForNull public final V remove(@CheckForNull Object o)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
remove
in interfaceMap<K,V>
- Throws:
UnsupportedOperationException
- always
-
putAll
@Deprecated public final void putAll(Map<? extends K,? extends V> map)
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
putAll
in interfaceMap<K,V>
- Throws:
UnsupportedOperationException
- always
-
clear
@Deprecated public final void clear()
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
clear
in interfaceMap<K,V>
- Throws:
UnsupportedOperationException
- always
-
containsKey
public boolean containsKey(@CheckForNull Object key)
- Specified by:
containsKey
in interfaceMap<K,V>
-
containsValue
public boolean containsValue(@CheckForNull Object value)
- Specified by:
containsValue
in interfaceMap<K,V>
-
get
@CheckForNull public abstract V get(@CheckForNull Object key)
-
getOrDefault
@CheckForNull public final V getOrDefault(@CheckForNull Object key, @CheckForNull V defaultValue)
See
Map.getOrDefault
.- Specified by:
getOrDefault
in interfaceMap<K,V>
- Since:
- 23.5 (but since 21.0 in the JRE flavor). Note, however, that Java 8+ users can call this method with any version and flavor of Guava.
-
entrySet
public ImmutableSet<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.
-
keySet
public ImmutableSet<K> keySet()
Returns an immutable set of the keys in this map, in the same order that they appear inentrySet
.
-
values
public ImmutableCollection<V> values()
Returns an immutable collection of the values in this map, in the same order that they appear inentrySet
.
-
asMultimap
public ImmutableSetMultimap<K,V> asMultimap()
Returns a multimap view of the map.- Since:
- 14.0
-
equals
public boolean equals(@CheckForNull Object object)
-
hashCode
public int hashCode()
-
-