Class ImmutableMap<K,V>
- All Implemented Interfaces:
Serializable
,Map<K,
V>
- Direct Known Subclasses:
ImmutableBiMap
,ImmutableSortedMap
Map
with reliable user-specified iteration
order. Does not permit null keys or values.
Unlike Collections.unmodifiableMap(java.util.Map<? extends K, ? extends V>)
, which is a view of a
separate map which can still change, an instance of ImmutableMap
contains its own data and will never change. ImmutableMap
is
convenient for public static final
maps ("constant maps") and also
lets you easily make a "defensive copy" of a map provided to your class by a
caller.
Performance notes: unlike HashMap
, ImmutableMap
is
not optimized for element types that have slow Object.equals(java.lang.Object)
or
Object.hashCode()
implementations. You can get better performance by
having your element type cache its own hash codes, and by making use of the
cached values to short-circuit a slow equals
algorithm.
See the Guava User Guide article on immutable collections.
- Since:
- 2.0 (imported from Google Collections Library)
- See Also:
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic class
Deprecated.The Google Guava Core Libraries are deprecated and will not be part of the AEM SDK after April 2023 -
Method Summary
Modifier and TypeMethodDescriptionDeprecated.Returns a multimap view of the map.static <K,
V> ImmutableMap.Builder <K, V> builder()
Deprecated.Returns a new builder.final void
clear()
Deprecated.Unsupported operation.boolean
containsKey
(Object key) Deprecated.boolean
containsValue
(Object value) Deprecated.static <K,
V> ImmutableMap <K, V> Deprecated.Returns an immutable map containing the same entries asmap
.entrySet()
Deprecated.Returns an immutable set of the mappings in this map.boolean
Deprecated.abstract V
Deprecated.int
hashCode()
Deprecated.boolean
isEmpty()
Deprecated.keySet()
Deprecated.Returns an immutable set of the keys in this map.static <K,
V> ImmutableMap <K, V> of()
Deprecated.Returns the empty map.static <K,
V> ImmutableMap <K, V> of
(K k1, V v1) Deprecated.Returns an immutable map containing a single entry.static <K,
V> ImmutableMap <K, V> of
(K k1, V v1, K k2, V v2) Deprecated.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) Deprecated.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) Deprecated.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) Deprecated.Returns an immutable map containing the given entries, in order.final V
Deprecated.Unsupported operation.final void
Deprecated.Unsupported operation.final V
Deprecated.Unsupported operation.toString()
Deprecated.values()
Deprecated.Returns an immutable collection of the values in this map.Methods inherited from interface java.util.Map
compute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll, size
-
Method Details
-
of
Deprecated.Returns the empty map. This map behaves and performs comparably toCollections.emptyMap()
, and is preferable mainly for consistency and maintainability of your code. -
of
Deprecated.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
Deprecated.Returns an immutable map containing the given entries, in order.- Throws:
IllegalArgumentException
- if duplicate keys are provided
-
of
Deprecated.Returns an immutable map containing the given entries, in order.- Throws:
IllegalArgumentException
- if duplicate keys are provided
-
of
Deprecated.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) Deprecated.Returns an immutable map containing the given entries, in order.- Throws:
IllegalArgumentException
- if duplicate keys are provided
-
builder
Deprecated.Returns a new builder. The generated builder is equivalent to the builder created by theImmutableMap.Builder
constructor. -
copyOf
Deprecated.Returns an immutable map containing the same entries asmap
. 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
-
put
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
put
in interfaceMap<K,
V> - Throws:
UnsupportedOperationException
- always
-
remove
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.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
putAll
in interfaceMap<K,
V> - Throws:
UnsupportedOperationException
- always
-
clear
Deprecated.Unsupported operation.Guaranteed to throw an exception and leave the map unmodified.- Specified by:
clear
in interfaceMap<K,
V> - Throws:
UnsupportedOperationException
- always
-
isEmpty
public boolean isEmpty()Deprecated. -
containsKey
Deprecated.- Specified by:
containsKey
in interfaceMap<K,
V>
-
containsValue
Deprecated.- Specified by:
containsValue
in interfaceMap<K,
V>
-
get
Deprecated. -
entrySet
Deprecated.Returns an immutable set of the mappings in this map. The entries are in the same order as the parameters used to build this map. -
keySet
Deprecated.Returns an immutable set of the keys in this map. These keys are in the same order as the parameters used to build this map. -
values
Deprecated.Returns an immutable collection of the values in this map. The values are in the same order as the parameters used to build this map. -
asMultimap
Deprecated.Returns a multimap view of the map.- Since:
- 14.0
-
equals
Deprecated. -
hashCode
public int hashCode()Deprecated. -
toString
Deprecated.
-