Class ImmutableBiMap<K,​V>

    • Method Detail

      • toImmutableBiMap

        public static <T extends @Nullable Object,​K,​V> Collector<T,​?,​ImmutableBiMap<K,​V>> toImmutableBiMap​(Function<? super T,​? extends K> keyFunction,
                                                                                                                                         Function<? super T,​? extends V> valueFunction)
        Returns a Collector that accumulates elements into an ImmutableBiMap whose keys and values are the result of applying the provided mapping functions to the input elements. Entries appear in the result ImmutableBiMap in encounter order.

        If the mapped keys or values contain duplicates (according to Object.equals(Object), an IllegalArgumentException is thrown when the collection operation is performed. (This differs from the Collector returned by Collectors.toMap(Function, Function), which throws an IllegalStateException.)

        Since:
        21.0
      • of

        public static <K,​V> ImmutableBiMap<K,​V> of()
        Returns the empty bimap.

        Performance note: the instance returned is a singleton.

        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Returns:
        an empty Map
      • of

        public static <K,​V> ImmutableBiMap<K,​V> of​(K k1,
                                                               V v1)
        Returns an immutable bimap containing a single entry.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the mapping's key
        v1 - the mapping's value
        Returns:
        a Map containing the specified mapping
      • of

        public 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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
      • of

        public 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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
      • of

        public 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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
      • of

        public 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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
      • of

        public 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,
                                                               K k6,
                                                               V v6)
        Returns an immutable map containing the given entries, in order.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        k6 - the sixth mapping's key
        v6 - the sixth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
        Since:
        31.0
      • of

        public 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,
                                                               K k6,
                                                               V v6,
                                                               K k7,
                                                               V v7)
        Returns an immutable map containing the given entries, in order.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        k6 - the sixth mapping's key
        v6 - the sixth mapping's value
        k7 - the seventh mapping's key
        v7 - the seventh mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
        Since:
        31.0
      • of

        public 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,
                                                               K k6,
                                                               V v6,
                                                               K k7,
                                                               V v7,
                                                               K k8,
                                                               V v8)
        Returns an immutable map containing the given entries, in order.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        k6 - the sixth mapping's key
        v6 - the sixth mapping's value
        k7 - the seventh mapping's key
        v7 - the seventh mapping's value
        k8 - the eighth mapping's key
        v8 - the eighth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
        Since:
        31.0
      • of

        public 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,
                                                               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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        k6 - the sixth mapping's key
        v6 - the sixth mapping's value
        k7 - the seventh mapping's key
        v7 - the seventh mapping's value
        k8 - the eighth mapping's key
        v8 - the eighth mapping's value
        k9 - the ninth mapping's key
        v9 - the ninth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
        Since:
        31.0
      • of

        public 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,
                                                               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.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        k1 - the first mapping's key
        v1 - the first mapping's value
        k2 - the second mapping's key
        v2 - the second mapping's value
        k3 - the third mapping's key
        v3 - the third mapping's value
        k4 - the fourth mapping's key
        v4 - the fourth mapping's value
        k5 - the fifth mapping's key
        v5 - the fifth mapping's value
        k6 - the sixth mapping's key
        v6 - the sixth mapping's value
        k7 - the seventh mapping's key
        v7 - the seventh mapping's value
        k8 - the eighth mapping's key
        v8 - the eighth mapping's value
        k9 - the ninth mapping's key
        v9 - the ninth mapping's value
        k10 - the tenth mapping's key
        v10 - the tenth mapping's value
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are added
        Since:
        31.0
      • ofEntries

        @SafeVarargs
        public static <K,​V> ImmutableBiMap<K,​V> ofEntries​(Map.Entry<? extends K,​? extends V>... entries)
        Returns an immutable map containing the given entries, in order.
        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        entries - Map.Entrys containing the keys and values from which the map is populated
        Returns:
        a Map containing the specified mappings
        Throws:
        IllegalArgumentException - if duplicate keys or values are provided
        Since:
        31.0
        See Also:
        Map.entry()
      • builderWithExpectedSize

        @Beta
        public static <K,​V> ImmutableBiMap.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 before ImmutableBiMap.Builder.build() is called, the builder is likely to perform better than an unsized builder() 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> ImmutableBiMap<K,​V> copyOf​(Map<? extends K,​? extends V> map)
        Returns an immutable bimap containing the same entries as 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.

        The returned BiMap iterates over entries in the same order as the entrySet of the original map.

        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.

        Type Parameters:
        K - the Map's key type
        V - the Map's value type
        Parameters:
        map - a Map from which entries are drawn, must be non-null
        Returns:
        a Map containing the entries of the given Map
        Throws:
        IllegalArgumentException - if two keys have the same value or two values have the same key
        NullPointerException - if any key or value in map is null
      • copyOf

        @Beta
        public static <K,​V> ImmutableBiMap<K,​V> copyOf​(Iterable<? extends Map.Entry<? extends K,​? extends V>> entries)
        Returns an immutable bimap containing the given entries. The returned bimap iterates over entries in the same order as the original iterable.
        Throws:
        IllegalArgumentException - if two keys have the same value or two values have the same key
        NullPointerException - if any key, value, or entry is null
        Since:
        19.0
      • inverse

        public abstract ImmutableBiMap<V,​Kinverse()
        Returns the inverse view of this bimap, which maps each of this bimap's values to its associated key. The two bimaps are backed by the same data; any changes to one will appear in the other.

        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.

        Specified by:
        inverse in interface BiMap<K,​V>
        Returns:
        the inverse view of this bimap
      • forcePut

        @CanIgnoreReturnValue
        @Deprecated
        @CheckForNull
        public final V forcePut​(K key,
                                V value)
        Deprecated.
        Unsupported operation.
        Guaranteed to throw an exception and leave the bimap unmodified.
        Specified by:
        forcePut in interface BiMap<K,​V>
        Parameters:
        key - the key with which the specified value is to be associated
        value - the value to be associated with the specified key
        Returns:
        the value that was previously associated with the key, or null if there was no previous entry. (If the bimap contains null values, then forcePut, like put, returns null both if the key is absent and if it is present with a null value.)
        Throws:
        UnsupportedOperationException - always