जावा कॉनसीरैबिलिटी - कॉन्ट्रासट्रैप इंटरफेस

Java.util.concurrent.ConcurrentMap इंटरफ़ेस, मानचित्र इंटरफ़ेस का एक उप-संस्करण है, जो अंतर्निहित मानचित्र चर पर परमाणु संचालन का समर्थन करता है। इसके पास ऐसी विधियाँ हैं और सेट करती हैं जो अस्थिर चरों पर पढ़ती और लिखती हैं। यही है, एक सेट में एक ही चर पर किसी भी बाद के साथ संबंध होने से पहले होता है। यह इंटरफ़ेस थ्रेड सुरक्षा और परमाणु सुरक्षा की गारंटी देता है।

समवर्ती नक्शा तरीके

अनु क्रमांक। विधि और विवरण
1

default V compute(K key, BiFunction<? super K,? super V,? extends V> remappingFunction)

निर्दिष्ट कुंजी और उसके वर्तमान मैप किए गए मान के लिए एक मैपिंग की गणना करने का प्रयास (या यदि कोई वर्तमान मैपिंग नहीं है तो अशक्त)।

2

default V computeIfAbsent(K key, Function<? super K,? extends V> mappingFunction)

यदि निर्दिष्ट कुंजी पहले से ही एक मूल्य से जुड़ी नहीं है (या नल के लिए मैप की गई है), दिए गए मैपिंग फ़ंक्शन का उपयोग करके इसके मूल्य की गणना करने का प्रयास करता है और इसे इस नक्शे में तब तक दर्ज करता है जब तक कि शून्य न हो।

3

default V computeIfPresent(K key, BiFunction<? super K,? super V,? extends V> remappingFunction)

यदि निर्दिष्ट कुंजी के लिए मान मौजूद है और गैर-शून्य है, तो कुंजी और उसके वर्तमान मैप किए गए मान को देखते हुए एक नई मैपिंग की गणना करने का प्रयास करता है।

4

default void forEach(BiConsumer<? super K,? super V> action)

इस मानचित्र में प्रत्येक प्रविष्टि के लिए दी गई कार्रवाई तब तक करता है जब तक कि सभी प्रविष्टियों को संसाधित नहीं किया गया हो या कार्रवाई अपवाद न हो।

5

default V getOrDefault(Object key, V defaultValue)

उस मान को लौटाता है जिसमें निर्दिष्ट कुंजी मैप की गई है, या डिफ़ॉल्टवैल्यू है यदि इस नक्शे में कुंजी के लिए कोई मैपिंग नहीं है।

6

default V merge(K key, V value, BiFunction<? super V,? super V,? extends V> remappingFunction)

यदि निर्दिष्ट कुंजी पहले से ही एक मूल्य से जुड़ी नहीं है या शून्य से जुड़ी है, तो इसे दिए गए गैर-शून्य मान के साथ जोड़ देता है।

7

V putIfAbsent(K key, V value)

यदि निर्दिष्ट कुंजी पहले से ही किसी मान से संबद्ध नहीं है, तो उसे दिए गए मान से जोड़ दें।

8

boolean remove(Object key, Object value)

किसी कुंजी के लिए प्रविष्टि तभी निकालता है जब वर्तमान में दिए गए मान पर मैप किया जाता है।

9

V replace(K key, V value)

कुंजी के लिए प्रविष्टि को केवल तभी बदलता है जब वर्तमान में कुछ मूल्य पर मैप किया जाता है।

10

boolean replace(K key, V oldValue, V newValue)

कुंजी के लिए प्रविष्टि को केवल तभी बदलता है जब वर्तमान में किसी दिए गए मान पर मैप किया जाता है।

1 1

default void replaceAll(BiFunction<? super K,? super V,? extends V> function)

उस प्रविष्टि पर दिए गए फ़ंक्शन को लागू करने के परिणामस्वरूप प्रत्येक प्रविष्टि के मूल्य को प्रतिस्थापित करता है जब तक कि सभी प्रविष्टियों को संसाधित नहीं किया जाता है या फ़ंक्शन अपवाद को नहीं फेंकता है।

उदाहरण

निम्न TestThread प्रोग्राम, ConcurrentMap vs HashMap का उपयोग दिखाता है।

import java.util.ConcurrentModificationException;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;

public class TestThread {

   public static void main(final String[] arguments) {
      Map<String,String> map = new ConcurrentHashMap<String, String>();

      map.put("1", "One");
      map.put("2", "Two");
      map.put("3", "Three");
      map.put("5", "Five");
      map.put("6", "Six");

      System.out.println("Initial ConcurrentHashMap: " + map);
      Iterator<String> iterator = map.keySet().iterator();

      try { 
         
         while(iterator.hasNext()) {
            String key = iterator.next();
            
            if(key.equals("3")) {
               map.put("4", "Four");
            }
         }
      } catch(ConcurrentModificationException cme) {
         cme.printStackTrace();
      }
      System.out.println("ConcurrentHashMap after modification: " + map);

      map = new HashMap<String, String>();

      map.put("1", "One");
      map.put("2", "Two");
      map.put("3", "Three");
      map.put("5", "Five");
      map.put("6", "Six");

      System.out.println("Initial HashMap: " + map);
      iterator = map.keySet().iterator();

      try {
         
         while(iterator.hasNext()) {
            String key = iterator.next();
            
            if(key.equals("3")) {
               map.put("4", "Four");
            }
         }
         System.out.println("HashMap after modification: " + map);
      } catch(ConcurrentModificationException cme) {
         cme.printStackTrace();
      }
   }  
}

यह निम्नलिखित परिणाम का उत्पादन करेगा।

उत्पादन

Initial ConcurrentHashMap: {1 = One, 2 = Two, 3 = Three, 5 = Five, 6 = Six}
ConcurrentHashMap after modification: {1 = One, 2 = Two, 3 = Three, 4 = Four, 5 = Five, 6 = Six}
Initial HashMap: {1 = One, 2 = Two, 3 = Three, 5 = Five, 6 = Six}
java.util.ConcurrentModificationException
	at java.util.HashMap$HashIterator.nextNode(Unknown Source)
	at java.util.HashMap$KeyIterator.next(Unknown Source)
	at TestThread.main(TestThread.java:48)