@GwtCompatible(serializable=true, emulated=true) public abstract class ImmutableBiMap<K,V> extends ImmutableMap<K,V> implements BiMap<K,V>
BiMap with reliable user-specified iteration order. Does
not permit null keys or values. An ImmutableBiMap and its inverse
have the same iteration ordering.
An instance of ImmutableBiMap contains its own data and will
never change. ImmutableBiMap is convenient for
public static final maps ("constant maps") and also lets you easily
make a "defensive copy" of a bimap provided to your class by a caller.
Note: Although this class is not final, it cannot be subclassed as it has no public or protected constructors. Thus, instances of this class are guaranteed to be immutable.
| Modifier and Type | Class and Description |
|---|---|
static class |
ImmutableBiMap.Builder<K,V>
A builder for creating immutable bimap instances, especially
public
static final bimaps ("constant bimaps"). |
| Modifier and Type | Method and Description |
|---|---|
static <K,V> ImmutableBiMap.Builder<K,V> |
builder()
Returns a new builder.
|
boolean |
containsKey(Object key) |
boolean |
containsValue(Object value) |
static <K,V> ImmutableBiMap<K,V> |
copyOf(Map<? extends K,? extends V> map)
Returns an immutable bimap containing the same entries as
map. |
boolean |
equals(Object object) |
V |
forcePut(K key,
V value)
Guaranteed to throw an exception and leave the bimap unmodified.
|
V |
get(Object key) |
int |
hashCode() |
abstract ImmutableBiMap<V,K> |
inverse()
Returns the inverse view of this bimap, which maps each of this bimap's
values to its associated key.
|
boolean |
isEmpty() |
ImmutableSet<K> |
keySet()
Returns an immutable set of the keys in this map.
|
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.
|
int |
size() |
String |
toString() |
ImmutableSet<V> |
values()
Returns an immutable set of the values in this map.
|
clear, entrySet, put, putAll, removepublic static <K,V> ImmutableBiMap<K,V> of()
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1)
public static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2)
IllegalArgumentException - if duplicate keys or values are addedpublic static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2, K k3, V v3)
IllegalArgumentException - if duplicate keys or values are addedpublic static <K,V> ImmutableBiMap<K,V> of(K k1, V v1, K k2, V v2, K k3, V v3, K k4, V v4)
IllegalArgumentException - if duplicate keys or values are addedpublic 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)
IllegalArgumentException - if duplicate keys or values are addedpublic static <K,V> ImmutableBiMap.Builder<K,V> builder()
ImmutableBiMap.Builder constructor.public static <K,V> ImmutableBiMap<K,V> copyOf(Map<? extends K,? extends V> map)
map. If
map somehow contains entries with duplicate keys (for example, if
it is a SortedMap 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.
IllegalArgumentException - if two keys have the same valueNullPointerException - if any key or value in map is nullpublic abstract ImmutableBiMap<V,K> inverse()
Note:There is no guaranteed correspondence between the iteration order of a bimap and that of its inverse.
The inverse of an ImmutableBiMap is another
ImmutableBiMap.
public boolean containsKey(@Nullable Object key)
containsKey in interface Map<K,V>containsKey in class ImmutableMap<K,V>public boolean containsValue(@Nullable Object value)
containsValue in interface Map<K,V>containsValue in class ImmutableMap<K,V>public ImmutableSet<K> keySet()
ImmutableMappublic ImmutableSet<V> values()
public V forcePut(K key, V value)
forcePut in interface BiMap<K,V>key - the key with which the specified value is to be associatedvalue - the value to be associated with the specified keynull, or null if there was no previous entryUnsupportedOperationException - alwayspublic boolean isEmpty()
public int hashCode()
public String toString()
toString in class ImmutableMap<K,V>Copyright © 2010-2015. All Rights Reserved.