Saturday, November 16, 2024
Google search engine
HomeLanguagesJavaAbstractMap in Java

AbstractMap in Java

The AbstractMap class is a part of the Java Collection Framework. It directly implements the Map interface to provide a structure to it, by doing so it makes the further implementations easier. As the name suggests AbstractMap is an abstract class by definition, therefore it cannot be used to create objects. The concrete classes that inherit from AbstractMap can be used to create objects.

Declaration:

public abstract class AbstractMap<K,V> extends Object, implements Map<K,V>

Here, K is the key type and V is the value type.

Hierarchy of AbstractMap

AbstractMap Hierarchy in Java

This class implements Map<K, V> interface and extends Object class.

Constructors of AbstractMap

Constructor

Definition

protected AbstractMap() This constructor cannot be used for creating objects. This constructor exists so that the inheriting classes can invoke it, this invocation is implicit.

Basic Operations

1. Adding Elements

To add elements to an AbstractMap we use the put() method. Note that the method is not actually of type AbstractMap but of an extending class, the reference to this object is of type AbstractMap. The entries of the map are of type key, value pair. Here the key is of type Integer and the value id of type String, this is mentioned at the time of instantiation of the object.

Java




// Java Program to demonstrate adding
// elements to the AbstractMap
  
import java.util.*;
  
public class AddElements {
  
    public static void main(String[] args)
    {
        // Since AbstractMap is an abstract class
        // create object using HashMap
        AbstractMap<Integer, String> absMap
            = new HashMap<Integer, String>();
  
        // Adding values to the AbstractMap
        // Note that we do not create an object of
        // AbstractMap
        absMap.put(1, "This");
        absMap.put(2, "is");
        absMap.put(3, "an");
        absMap.put(4, "AbstractMap");
  
        // Displaying the mappings using
        // entrySet() to get the set view
        System.out.println("The Set view of the mappings:");
        System.out.println(absMap.entrySet());
    }
}


Output

The Set view of the mappings:
[1=This, 2=is, 3=an, 4=AbstractMap]

2. Removing Elements

We can remove mappings from an AbstractMap using the remove() method. The syntax of remove is 

mapName.remove(Object key);

This will remove the value mapped to the specified key. We can clear the entire AbstractMap using the clear() method as shown below.

Java




// Java Program to demonstrate removing
// elements from the AbstractMap
  
import java.util.*;
  
public class RemoveElements {
  
    public static void main(String[] args)
    {
        // Since AbstractMap is an abstract class
        // create object using HashMap
        AbstractMap<Integer, String> absMap
            = new HashMap<Integer, String>();
  
        absMap.put(1, "This");
        absMap.put(2, "is");
        absMap.put(3, "an");
        absMap.put(4, "AbstractMap");
  
        // Displaying the mappings
        System.out.println("Mappings of the AbstractMap:");
        System.out.println(absMap);
  
        // Removing an entry using the remove() method
        absMap.remove(1);
  
        // Displaying the mappings
        System.out.println("Mappings of the AbstractMap:");
        System.out.println(absMap);
  
        // Clearing the whole map using clear()
        absMap.clear();
  
        // Displaying the mappings
        System.out.println("\nThe Set view of the mappings:");
        System.out.println(absMap);
    }
}


Output

Mappings of the AbstractMap:
{1=This, 2=is, 3=an, 4=AbstractMap}
Mappings of the AbstractMap:
{2=is, 3=an, 4=AbstractMap}

The Set view of the mappings:
{}

3. Replacing entries

We can replace values associated with a key using the replace() method as shown below.

Java




// Java Program to demonstrate replacing
// elements of AbstractMap
  
import java.util.AbstractMap;
import java.util.HashMap;
  
public class ReplaceElements {
  
    public static void main(String[] args)
    {
  
        // Since AbstractMap is an abstract class
        // create object using HashMap
        AbstractMap<Integer, String> absMap
            = new HashMap<Integer, String>();
  
        // Adding values to the AbstractMap
        // Note that we do not create an object of
        // AbstractMap
        absMap.put(1, "This");
        absMap.put(2, "is");
        absMap.put(3, "a");
        absMap.put(4, "AbstractMap");
  
        // Displaying the mappings
        System.out.println("Mappings of the AbstractMap:");
        System.out.println(absMap);
  
        // Replacing the mapping associated to 3
        absMap.replace(3, "an");
  
        // Displaying the mappings
        System.out.println("\nMappings of the AbstractMap:");
        System.out.println(absMap);
    }
}


Output

Mappings of the AbstractMap:
{1=This, 2=is, 3=a, 4=AbstractMap}

Mappings of the AbstractMap:
{1=This, 2=is, 3=an, 4=AbstractMap}

4. Traversing

There are different ways to traverse through an AbstractMap, we discuss two ways in the code given below. The first method is to use entrySet() method, which returns a collection view of the map. This view can be iterated through using a for each loop. The method getKey() return the key and getValue() return the associated value. The second method is by using the Iterator interface. We create an iterator over the key set using the keySet() method. This iterator is used to iterate over the map using the next() method, which returns the next entry in the map.

Java




// Java Program to demonstrate
// traversing AbstractMap
  
import java.util.*;
  
public class Traversing {
  
    public static void main(String[] args)
    {
        // Since AbstractMap is an abstract class
        // create object using HashMap
        AbstractMap<Integer, String> absMap
            = new HashMap<Integer, String>();
  
        // Adding values to the AbstractMap
        // Note that we do not create an object of
        // AbstractMap
        absMap.put(1, "This");
        absMap.put(2, "is");
        absMap.put(3, "a");
        absMap.put(4, "AbstractMap");
  
        // METHOD 1
        // Iterate over the map using entrySet()
        // which returns a collection view of the map
  
        System.out.println("Using the entrySet() method");
  
        for (AbstractMap.Entry<Integer, String> entry :
             absMap.entrySet()) {
            System.out.println("Key = " + entry.getKey()
                               + ", Value = "
                               + entry.getValue());
        }
  
        // METHOD 2
        // Iterate over the map using the Iterator interface
  
        System.out.println(
            "\nUsing the Iterator interface");
  
        Iterator<Integer> itr = absMap.keySet().iterator();
        while (itr.hasNext()) {
            int key = itr.next();
            System.out.println("Key = " + key
                               + ", Value =  "
                               + absMap.get(key));
        }
    }
}


Output

Using the entrySet() method
Key = 1, Value = This
Key = 2, Value = is
Key = 3, Value = a
Key = 4, Value = AbstractMap

Using the Iterator interface
Key = 1, Value =  This
Key = 2, Value =  is
Key = 3, Value =  a
Key = 4, Value =  AbstractMap

Inheriting Classes

1. HashMap

The HashMap class is the basic implementation of the Map interface, which stores the key-value pairs. The HashMap is a basic Map implementation of the Hashtable but HashMap is unsychronised. The order of elements of a HashMap is undefined. The HashMap provides constant time performance for basic operations of insertion, deletion, traversal and manipulation.

Syntax:

HashMap< ? , ? > hmName = new HashMap< ? , ? >();

2. IdentityHashMap

The IdentityHashMap is the Hashtable implementation of a Map, but it uses reference equality instead of object equality. Which means that IdentityHashMap violates the basic rule of maps, therefore it is not a general-purpose map, it is reserved for rare scenarios. In an IdentityHashMap any two objects, o1 and o2, are equal if and only if o1==o2 i.e. the reference of o1 and o2 are the same.

Syntax:

IdentityHashMap< ? , ? > ihmName = new IdentityHashMap< ? , ? >();

3. WeakHashMap

The WeakHashMap is a Hashtable implementation of the Map interface that uses weak keys. When a key in a WeakHashMap is no longer in ordinary use it will be automatically discarded. It means that the existence of a mapping will not prevent the key from being garbage collected. The WeakHashMap is an unsynchronised class.

Syntax:

WeakHashMap< ? , ? > whmName = new WeakHashMap< ? , ? >();

4. TreeMap

The TreeMap class is a Red-Black tree based implementation of the NavigableMap. The TreeMap elements are sorted either by the natural order or by the Comparator provided at the time of construction.

Syntax:

TreeMap< ? , ? > tmName = new TreeMap< ? , ? >();

5. EnumMap

The EnumMap is a specialized implementation of the Map interface. The keys of the EnumMap are of type enum. All the keys must be of the same enum, either defined explicitly or implicitly, specified at the time of construction. The EnumMap is internally represented as an array, it is very compact and efficient.

Syntax:

EnumMap< enumName, ? > emName = new EnumMap< enumName, ? >();

6. ConcurrentHashMap

The ConcurrentHashMap is a Hashtable implementation that supports full concurrency through retrieve and update operations. This class is highly compatible with the Hashtable class and contains all corresponding methods of a Hashtable. Although the operations are thread-safe there is no locking mechanism in place, therefore retrieval can overlap updation. Therefore, retrieval operations reflect the most recently completed update operations.

Syntax:

ConcurrentHashMap< ? , ? > chmName = new ConcurrentHashMap< ? , ? >();

7. ConcurrentSkipListMap

The ConcurrentSkipListMap is a scalable implementation of the ConcurrentNavigableMap interface. The keys in ConcurrentSkipListMap are sorted by natural order or by using a Comparator at the time of construction of the object. The ConcurrentSkipListMap has the expected time cost of log n for insertion, deletion and searching operations. It is a thread-safe class, therefore, all basic operations can be accomplished concurrently.

Syntax:

ConcurrentSkipListMap< ? , ? > cslmName = new ConcurrentSkipListMap< ? , ? >();

Methods of AbstractMap

METHOD

DESCRIPTION

clear() Removes all of the mappings from this map (optional operation).
clone() Returns a shallow copy of this AbstractMap instance: the keys and values themselves are not cloned.
containsKey​(Object key) Returns true if this map contains a mapping for the specified key.
containsValue​(Object value) Returns true if this map maps one or more keys to the specified value.
equals​(Object o) Compares the specified object with this map for equality.
get​(Object key)  Returns the value to which the specified key is mapped, or null if this map contains no mapping for the key.
hashCode()  Returns the hash code value for this map.
isEmpty() Returns true if this map contains no key-value mappings.
keySet()  Returns a Set view of the keys contained in this map.
put​(K key, V value)  Associates the specified value with the specified key in this map (optional operation).
putAll​(Map<? extends K,​? extends V> m)  Copies all of the mappings from the specified map to this map (optional operation).
remove​(Object key)  Removes the mapping for a key from this map if it is present (optional operation).
size()  Returns the number of key-value mappings in this map.
toString()  Returns a string representation of this map.
values()  Returns a Collection view of the values contained in this map.

Methods declared in interface java.util.Map

METHOD

DESCRIPTION

compute​(K key, BiFunction<? super K,​? super V,​? extends V> remappingFunction) Attempts to compute a mapping for the specified key and its current mapped value (or null if there is no current mapping).
computeIfAbsent​(K key, Function<? super K,​? extends V> mappingFunction) If the specified key is not already associated with a value (or is mapped to null), attempts to compute its value using the given mapping function and enters it into this map unless null.
computeIfPresent​(K key, BiFunction<? super K,​? super V,​? extends V> remappingFunction) If the value for the specified key is present and non-null, attempts to compute a new mapping given the key and its current mapped value.
entrySet() Returns a Set view of the mappings contained in this map.
forEach​(BiConsumer<? super K,​? super V> action) Performs the given action for each entry in this map until all entries have been processed or the action throws an exception.
getOrDefault​(Object key, V defaultValue) Returns the value to which the specified key is mapped, or defaultValue if this map contains no mapping for the key.
merge​(K key, V value, BiFunction<? super V,​? super V,​? extends V> remappingFunction) If the specified key is not already associated with a value or is associated with null, associates it with the given non-null value.
putIfAbsent​(K key, V value) If the specified key is not already associated with a value (or is mapped to null) associates it with the given value and returns null, else returns the current value.
remove​(Object key, Object value) Removes the entry for the specified key only if it is currently mapped to the specified value.
replace​(K key, V value) Replaces the entry for the specified key only if it is currently mapped to some value.
replace​(K key, V oldValue, V newValue) Replaces the entry for the specified key only if currently mapped to the specified value.
replaceAll​(BiFunction<? super K,​? super V,​? extends V> function) Replaces each entry’s value with the result of invoking the given function on that entry until all entries have been processed or the function throws an exception.

 

RELATED ARTICLES

Most Popular

Recent Comments