CodeGym /Java Blog /சீரற்ற /ஜாவாவில் HashMap computeIfAbsent() முறை
John Squirrels
நிலை 41
San Francisco

ஜாவாவில் HashMap computeIfAbsent() முறை

சீரற்ற குழுவில் வெளியிடப்பட்டது
ஜாவா 8, நம்மில் பலருக்குத் தெரியும், ஸ்ட்ரீம் ஏபிஐ அறிமுகப்படுத்தியது. இது மிகவும் பயனுள்ள கருவித்தொகுப்பு, ஆனால் இது ஒரு குறைபாட்டைக் கொண்டுள்ளது, இதில் வரைபடங்கள் இல்லை . இருப்பினும், ஜாவா 8 "மோசமான" குறியீட்டின் அளவைக் குறைக்க வரைபட இடைமுகத்திலேயே பல பயனுள்ள முறைகளைச் சேர்த்தது . எனவே, நீங்கள் வரைபடத்தில் உள்ள மதிப்பைக் கொண்டு சில செயல்களைச் செய்ய வேண்டும் என்றால் , அது அதில் இருந்தால், ஜாவா வரைபடத்தில் ComputeIfPresent() முறை உள்ளது. வரைபடத்தில் இல்லாத மதிப்பைக் கொண்டு நீங்கள் ஏதாவது செய்ய வேண்டும் என்றால் , ComputeIfAbsent() முறையைப் பயன்படுத்தலாம் . அதை இந்தக் கட்டுரையில் பரிசீலிப்போம்.

ComputeIfAbsent() முறை கையொப்பம்


default V computeIfAbsent(K key, Function<? super K, ? extends V> mappingFunction)
Map ( மற்றும் HashMap ) computeIfAbsent() முறை இரண்டு அளவுருக்களை எடுக்கும். முதல் அளவுரு முக்கியமானது. இரண்டாவது அளவுரு மேப்பிங் செயல்பாடு ஆகும் . இந்த முறையில், மேப்பிங் வழங்கப்படாவிட்டால் மட்டுமே மேப்பிங் செயல்பாடு அழைக்கப்படுகிறது.

ComputeIfAbsent() முறை எவ்வாறு செயல்படுகிறது

நாம் ஏற்கனவே அறிந்தபடி, Map.computeIfAbsent() முறை இரண்டு அளவுருக்கள், விசை மற்றும் இந்த விசை மேப்பிங் செயல்பாடுக்கான மதிப்பைக் கணக்கிடுவதற்கான செயல்பாடு . முறையின் தர்க்கரீதியான அல்காரிதம் இங்கே:
  1. அனுப்பப்பட்ட விசை எங்கள் வரைபடத்தில் குறிப்பிடப்பட்டுள்ளதா என்பதை இந்த முறை முதலில் சரிபார்க்கிறது .
  2. விசை வரைபடத்தில் குறிப்பிடப்பட்டிருந்தால் (அது பூஜ்யமாக இல்லை), பின்னர் முறை எதுவும் செய்யாது.
  3. இல்லையெனில், விசை வரைபடத்தில் குறிப்பிடப்படவில்லை என்றால் (அல்லது அது பூஜ்யமானது) இந்த முறை விசைக்கு மேப்பிங் செயல்பாட்டைப் பயன்படுத்தி மதிப்பைக் கணக்கிடுகிறது .
  4. இதன் விளைவாக வரும் மதிப்பு பூஜ்யமாக இல்லாவிட்டால், வரைபடத்திற்கு ஒரு முக்கிய மதிப்பு ஜோடியை எழுதவும்.
குறியீட்டின் அதே தர்க்கத்தை எழுதுவோம்:

if (map.get(key) == null) 
{ 
V newValue = mappingFunction.apply(key); 
if (newValue != null) map.put(key, newValue); 
}

ComputeIfAbsent() குறியீடு உதாரணம்

எனவே, மதிப்பானது வரைபடத்தில் இல்லை என்றால் , முறை மாற்றங்களைச் செய்யும். ஒரு எளிய உதாரணத்தைப் பார்ப்போம்:

import java.util.HashMap;
import java.util.Map;

//map.computeIfAbsent example 
public class ComputeIfAbsentExample {

       public static void main(String[] args) {

           Map<String, String> myMap = new HashMap<>();

           myMap.computeIfAbsent("here is my key", key -> key + ", " + "and this is a new value");

           System.out.println(myMap.get("here is my key"));
       }
}
வெளியீடு:
இதோ எனது திறவுகோல், இது ஒரு புதிய மதிப்பு
வரைபடத்தில் கொடுக்கப்பட்ட மதிப்பு இருக்கும் போது அந்த முறை என்ன செய்யும் என்று இப்போது பார்க்கலாம் . ஸ்பாய்லர் எச்சரிக்கை: இது எதையும் செய்யாது.

import java.util.HashMap;
import java.util.Map;

public class ComputeIfAbsentExample2 {

       public static void main(String[] args) {

           Map<String, String> myMap = new HashMap<>();
           myMap.put("here is my key", "and here is my value");

           myMap.computeIfAbsent("here is my key", key -> key + ", " + "and this is a new value");

           System.out.println(myMap.get("here is my key"));
       }
}
இதோ வெளியீடு:
இதோ என் மதிப்பு
நீங்கள் பார்க்க முடியும் என, மதிப்பு மாறாமல் உள்ளது.

மேலும் ஒரு ComputeIfAbsent() உதாரணம்

கேச்சிங் என்ற கருத்தை நீங்கள் நன்கு அறிந்திருந்தால், கம்ப்யூட்இஃப்அப்சென்ட்() முறை உங்களுக்கு ஏதாவது ஒன்றை நினைவூட்டுகிறது. மிகவும் சிக்கலான பாகுபடுத்தும் உதாரணத்தைப் பார்ப்போம். முதல் வழக்கில் மதிப்பு மாறாமல் இருப்பதை உறுதிசெய்ய, கம்ப்யூட்இஃப்அப்சென்ட்() முறையை இருமுறை அழைப்போம் .

import java.util.HashMap;
import java.util.Map;

public class ComputeIfAbsentExample {
   private static Map<String, Long> numbersMap = new HashMap<>();

   public static Long stringToLong(String str) {
       return numbersMap.computeIfAbsent(str, key -> {
           System.out.println("parsing: " + key);
           return Long.parseLong(key);
       });
   }

   public static void main(String[] args) {
       // will print:
       // > parsing: 10
       // > parsing: 25
       // > 10+25=35
       System.out.println("10+25=" + (stringToLong("10") + stringToLong("25")));
       // will print:
       // > parsing: 20
       // > 10+25=45
       // only "20" will be parsed this time, since "25" was already parsed and placed into `numbersMap` map before
       System.out.println("20+25=" + (stringToLong("20") + stringToLong("25")));
       // will print:
       // > 10+20=30
       // no parsing will occur, since both "10" and "20" were already parsed and placed into `numbersMap` map before
       System.out.println("10+20=" + (stringToLong("10") + stringToLong("20")));
   }

}
இதோ வெளியீடு:
பாகுபடுத்துதல்: 10 பாகுபடுத்துதல்: 25 10+25=35 பாகுபடுத்துதல்: 20 20+25=45 10+20=30
கருத்துக்கள்
TO VIEW ALL COMMENTS OR TO MAKE A COMMENT,
GO TO FULL VERSION