Home >Java >javaTutorial >Java LinkedHashMap
In Java, LinkedHashMap is an implementation of linkedlist from the interface Map. It is similar to HashMap, where an extra feature is included that maintains the order of elements that are being inserted into it. Even though HashMap provides quick insertion, deletion, and search, element insertion order is not maintained.
Start Your Free Software Development Course
Web development, programming languages, Software testing & others
In addition to that, several other features are also included in LinkedHashMap.
Syntax:
LinkedHashMap<Integer, String> obj = new LinkedHashMap<Integer, String>();
Here, obj is the object of the created LinkedHashMap.
Once the LinkedHashMap object is created, it will be used for adding elements to the map, as shown below.
obj.put(11, "Victor"); obj.put(33, "Shyla"); obj.put(14, "Nancy"); obj.put(100, "Kuffi"); obj.put(23, "Princy"); obj.put(37, "Chamm");
Given below are the constructors of a LinkedHashMap:
1. LinkedHashMap(): An empty LinkedHashMap instance will be created with the ordering based on insertion, load factor 0.75 and default initial capacity as 16.
2. LinkedHashMap(int initialCapacity): An empty LinkedHashMap instance will be created with the ordering based on insertion, load factor 0.75 and specified initial capacity.
3. LinkedHashMap(int initialCapacity, float loadFactor): An empty LinkedHashMap instance will be created with the ordering based on insertion, specified load factor, and initial capacity.
4. LinkedHashMap(int initialCapacity, float loadFactor, boolean accessOrder): An empty LinkedHashMap instance will be created with specified load factor, access order and initial capacity.
5. LinkedHashMap(Map extends K,? extends V> m): A LinkedHashMap instance will be created with the ordering based on insertion and mappings based on the mentioned map.
The following are the commonly used methods in LinkedHashMap.
1. clear(): Every mapping from the map will be removed.
2. boolean containsKey(Object key): If the map contains a mapping to one or more than one key of the value mentioned, true will be returned.
3. boolean containsValue(Object key): If the map contains a mapping to a minimum of one key, true will be returned.
4. Object get(Object key): The value of the mentioned key’s mapping will be returned.
5. isEmpty(): If there are no key-value pair mappings, true will be returned.
6. size(): Count of key-value pairs available in the map will be returned.
7. Object remove(Object key): The value of the mentioned key’s mapping will be removed.
8. boolean removeEldestEntry(Map.Entry eldest): If the eldest entry can be removed, true will be returned.
Given below are the examples of Java LinkedHashMap:
Java program to create a simple LinkedHashMap.
Code:
import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; //class begins here public class LinkedHashMapExample { //main method public static void main(String args[]) { // create a LinkedHashMap LinkedHashMap<Integer, String> obj = new LinkedHashMap<Integer, String>(); //Adding key-value pair 1 obj.put(11, "Anna"); //Adding key-value pair 2 obj.put(33, "Adam"); //Adding key-value pair 3 obj.put(14, "Iza"); //Adding key-value pair 4 obj.put(23, "Norah"); //Adding key-value pair 5 obj.put(100, "Denan"); // create an entry set Set s = obj.entrySet(); // Display the elements Iterator itr = s.iterator(); //iterate each element while(itr.hasNext()) { //create an object for map.entry Map.Entry mp = (Map.Entry)itr.next(); //print each element System.out.print("Key in the LinkedHashMap is : "+ mp.getKey() + " and it's corresponding value is: "+mp.getValue()+" \n"); } } }
Output:
In this program, a LinkedHashMap is created first. After that, elements are added to it with key-value pairs. Once it is completed, an entry set is created. Moreover, in order to print all the elements in the LinkedHashMap, an iterator is created. By iterating each element, it is printed and displayed as shown in the sample output.
Java program to remove key-value pair from the map.
Code:
import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; //class begins here public class LinkedHashMapExample { //main method public static void main(String args[]) { // create a LinkedHashMap LinkedHashMap<Integer, String> obj = new LinkedHashMap<Integer, String>(); //Adding key-value pair 1 obj.put(11, "Victor"); //Adding key-value pair 2 obj.put(33, "Shyla"); //Adding key-value pair 3 obj.put(14, "Nancy"); //Adding key-value pair 4 obj.put(100, "Kuffi"); //Adding key-value pair 5 obj.put(23, "Princy"); //Adding key-value pair 6 obj.put(37, "Chamm"); System.out.print("Before removal, LinkedHashMap is: "+obj+"\n"); //remove the elements with keys 100 and 37 obj.remove(100); obj.remove(37); System.out.print("After removal, LinkedHashMap is: "+obj); } }
Output:
In this program, also, a LinkedHashMap is created first. After that, elements are added to it with key-value pairs. Once it is completed, LinkedHashMap is printed. Then, two key-value pairs are removed from the map using the method remove(). After that, once again, the map is printed and displayed as shown in the sample output.
Java program to print key-value pairs in the map on the basis of access order.
Code:
import java.util.Iterator; import java.util.LinkedHashMap; import java.util.Map; import java.util.Set; //class begins here public class LinkedHashMapExample { //main method public static void main(String args[]) { // create a LinkedHashMap with third paramter set access order LinkedHashMap<Integer, String> obj = new LinkedHashMap<Integer, String>(2, .75f, true); //Adding key-value pair 1 obj.put(11, "Victor"); //Adding key-value pair 2 obj.put(33, "Shyla"); //Adding key-value pair 3 obj.put(14, "Nancy"); //Adding key-value pair 4 obj.put(100, "Kuffi"); //Adding key-value pair 5 obj.put(23, "Princy"); //Adding key-value pair 6 obj.put(37, "Chamm"); //Access the pair 33 obj.get(33); //Access the pair 11 obj.get(11); System.out.print("LinkedHashMap with access order is: "+obj); } }
Output:
Here, in this program also, a LinkedHashMap is created first. After that, elements are added to it with key-value pairs. Once it is completed, the elements with keys 33 and 11 are accessed. Then, the map is printed and displayed as shown in the sample output. It can be seen that the elements that are accessed are at the end of the map.
Almost all details on Java LinkedHashMap, such as syntax, constructors, methods, and examples, are explored in this article in detail. Moreover, it also identifies the main difference between LinkedHashMap and HashMap.
The above is the detailed content of Java LinkedHashMap. For more information, please follow other related articles on the PHP Chinese website!