Full Stack Web Development Internship Program
- 29k Enrolled Learners
- Weekend/Weekday
- Live Class
One of the most interesting topics in Java is the Map interface which represents a mapping between a key and a value. It is often misunderstood to be a subtype of Collection interface in Java. This article on Java Map Interface will help you understand and master how a map works in Java.
Listed below are the topics covered in this article:
A Map in Java is an object that maps keys to values and is designed for the faster lookups. Data is stored in key-value pairs and every key is unique. Each key maps to a value hence the name map. These key-value pairs are called map entries.
In the JDK, java.util.Map is an interface that includes method signatures for insertion, removal, and retrieval of elements based on a key. With such methods, it’s a perfect tool to use for key-value association mapping such as dictionaries.
Now that you have an idea of what Map interface in Java is, let’s go ahead and check out the hierarchy of Java Map.
There are two interfaces that implement the Map in java: Map and SortedMap. And popular implementation classes of Map in Java are HashMap, TreeMap, and LinkedHashMap. The hierarchy of Java Map is given below:
Before we check out the three implementation classes of the Java Map Interface mentioned above, here are some common methods that you can come across when working with the Map.
Methods | Description |
public put(Object key, Object value) | This method inserts an entry in the map |
public void putAll(Map map) | This method inserts the specified map in this map |
public Object remove(Object key) | It is used to delete an entry for the specified key |
public Set keySet() | It returns the Set view containing all the keys |
public Set entrySet() | It returns the Set view containing all the keys and values |
void clear() | It is used to reset the map |
public void putIfAbsent(K key, V value) | It inserts the specified value with the specified key in the map only if it is not already specified |
public Object get(Object key) | It returns the value for the specified key |
public boolean containsKey(Object key) | It is used to search the specified key from this map |
There are several classes that implement the Java Map but three major and general-purpose implementations are HashMap, TreeMap, and LinkedHashMap. Let’s see the characteristics and behaviors of each implementation with an example program.
The most common class that implements the Java Map interface is the HashMap. It is a hash table based implementation of the Map interface. It implements all of the Map operations and allows null values and one null key. Also, this class does not maintain any order among its elements. Here’s an example program demonstrating the HashMap class.
package MyPackage; import java.util.*; class HashMapExample { public static void main(String[] args) { Map< String, Integer> courses = new HashMap< String,Integer>(); // Add some courses. courses.put("Java Courses", new Integer(6)); courses.put("Cloud Courses", new Integer(7)); courses.put("Programming Courses", new Integer(5)); courses.put("Data Science Courses", new Integer(2)); System.out.println("Total courses: " + courses.size()); Set< Map.Entry< String,Integer> > st = courses.entrySet(); for (Map.Entry< String,Integer> me :st) { System.out.print(me.getKey()+":"); System.out.println(me.getValue()); } System.out.println(); String searchKey = "Java Courses"; if (courses.containsKey(searchKey)) System.out.println("Found total " + courses.get(searchKey) + " " + searchKey); } }
Output
Total courses: 4 Cloud Courses:7 Programming Courses:5 Data Science Courses:2 Java Courses:6 Found total 6 Java Courses
In the above program, I have used a lot of methods mention in the table. Firstly, the put() method inserts 4 entries into the map, and the size() method in the next step displays the size of the map (total key-value pairs). After that, in the next step, the entrySet() method returns all the key-value pairs. The program also shows how to make use of get() method to search for a value using the associated key.
Let’s move on to the next class that implements the Java Map Interface – TreeMap.
This implementation uses the Red-Black tree as the underlying data structure. A TreeMap is sorted according to the natural ordering of its keys, or by a Comparator provided at creation time. This implementation doesn’t allow nulls but maintains order on its elements. Here’s an example program demonstrating the TreeMap class.
package MyPackage; import java.util.*; class TreeMapEx{ public static void main(String[] args) { Map< String, Integer> courses = new TreeMap< String,Integer>(); // Add some courses. courses.put("Java Courses", new Integer(3)); courses.put("AWS Courses", new Integer(7)); courses.put("Programming Courses", new Integer(8)); courses.put("Data Science Courses", new Integer(2)); System.out.println("Total courses: " + courses.size()); Set< Map.Entry< String,Integer> > st = courses.entrySet(); for (Map.Entry< String,Integer> me :st) { System.out.print(me.getKey()+":"); System.out.println(me.getValue()); } System.out.println(); } }
Output
Total courses: 4 AWS Courses:7 Data Science Courses:2 Java Courses:3 Programming Courses:8
In the output, the elements of the map are printed in a strict lexicographic order, which does not appear in the previous examples of HashMap. The next class that we are going to discuss are LinkedHashMap.
As the name indicates this implementation of Java Map interface uses a hash table and a linked list as the underlying data structures. Thus the order of a LinkedHashMap is predictable, with insertion-order as the default order. Also, allows nulls like in HashMap. Here’s an example program demonstrating the TreeMap class.
package MyPackage; import java.util.*; public class LinkedHashMapExample { public static void main(String a[]) { LinkedHashMap<String, Integer> courses = new LinkedHashMap<String, Integer>(); courses.put("Java Courses", new Integer(3)); courses.put("Cloud Courses", new Integer(7)); courses.put("Programming Courses", new Integer(8)); courses.put("Data Science Courses", new Integer(2)); // It prints the elements in same order // as they were inserted System.out.println(courses); System.out.println("Total courses: " + courses.size()); System.out.println("Contains key 'Hadoop'? "+ courses.containsKey("Hadoop")); System.out.println("Getting value for key 'Programming Courses': " + courses.get("Programming Courses")); System.out.println("Is map empty? " + courses.isEmpty()); System.out.println("delete element 'Cloud Courses': " + courses.remove("Cloud Courses")); System.out.println(courses); } }
Output
{Java Courses=3, Cloud Courses=7, Programming Courses=8, Data Science Courses=2} Total courses: 4 Contains key 'Hadoop'? false Getting value for key 'Programming Courses': 8 Is map empty? false delete element 'Cloud Courses': 7 {Java Courses=3, Programming Courses=8, Data Science Courses=2}
The example program is pretty simple to understand. I have used some basic methods to demonstrate the functioning of LinkeHashMap in Java. Like I said earlier there apart from these three there are a lot of other classes that implement Java Map interface.
This brings us to the end of this ‘Java Map Interface’ article. I have covered one of the interesting topics of Java, which is Map interface in Java.
Make sure you practice as much as possible and revert your experience.
Check out the Java Certification Course by Edureka, a trusted online learning company with a network of more than 250,000 satisfied learners spread across the globe. We are here to help you with every step on your journey, for becoming a besides this java interview questions, we come up with a curriculum which is designed for students and professionals who want to be a Java Developer.
Got a question for us? Please mention it in the comments section of this ‘java Map interface’ article and we will get back to you as soon as possible.
Course Name | Date | Details |
---|---|---|
Java Course Online | Class Starts on 5th October,2024 5th October SAT&SUN (Weekend Batch) | View Details |
edureka.co