The computeIfPresent(Key, BiFunction) method of HashMap class which allows you to compute value of a mapping for specified key if key is already associated with a value (or is mapped to null).
- If mapping function of this method returns null, the mapping is removed.
- If the remapping function throws an exception, the exception is rethrown, and the mapping is left unchanged.
- During computation, modification this map using this method is not allowed.
Syntax:
public Object computeIfPresent(Object key, BiFunction remappingFunction)
Parameters: This method accepts two parameters:
- key: key with which the value is to be associated.
- remappingFunction: function to do the operation on value.
Returns: This method returns new remapped value associated with the specified key, or null if mapping returns null.
Below programs illustrate the computeIfPresent(Key, BiFunction) method:
Example 1: This example demonstrates the case when the key is not in the hashmap.
// Java program to demonstrate // computeIfPresent(Key, BiFunction) method.   import java.util.concurrent.*; import java.util.*;   public class GFG {     public static void main(String[] args)     {           // Create a HashMap and add some values         HashMap<String, Integer> wordCount = new HashMap<>();         wordCount.put( "Geeks" , 1 );         wordCount.put( "for" , 2 );         wordCount.put( "geeks" , 3 );           // print HashMap details         System.out.println( "Hashmap before operation :\n "                            + wordCount);           // provide new value for keys which is present         // using computeIfPresent method         wordCount.computeIfPresent( "Geek" ,                                    (key, val) -> val + 100 );           // print new mapping         System.out.println( "HashMap after operation :\n "                            + wordCount);     } } |
Hashmap before operation : {geeks=3, Geeks=1, for=2} HashMap after operation : {geeks=3, Geeks=1, for=2}
Example 2: This example demonstrates the case when the key is present in the hashmap.
// Java program to demonstrate // computeIfPresent(Key, BiFunction) method.   import java.util.concurrent.*; import java.util.*;   public class GFG {     public static void main(String[] args)     {           // Create a HashMap and add some values         HashMap<String, Integer> wordCount = new HashMap<>();         wordCount.put( "Geeks" , 1 );         wordCount.put( "for" , 2 );         wordCount.put( "geeks" , 3 );           // print HashMap details         System.out.println( "Hashmap before operation :\n "                            + wordCount);           // provide new value for keys which is present         // using computeIfPresent method         wordCount.computeIfPresent( "for" ,                                    (key, val) -> val + 1 );           // print new mapping         System.out.println( "HashMap after operation :\n "                            + wordCount);     } } |
Hashmap before operation : {geeks=3, Geeks=1, for=2} HashMap after operation : {geeks=3, Geeks=1, for=3}