Java मध्ये हॅशमॅप आणि हॅशटेबल समजून घेणे
जावा कलेक्शनच्या जगात, हॅशमॅप आणि हॅशटेबल हे की-व्हॅल्यू जोड्या संग्रहित करण्यासाठी मोठ्या प्रमाणात वापरल्या जाणाऱ्या दोन डेटा स्ट्रक्चर्स आहेत. जरी ते सारखे वाटत असले तरी, त्यांच्यात वेगळे फरक आहेत जे तुमच्या अनुप्रयोगाच्या कार्यप्रदर्शनावर आणि थ्रेड सुरक्षिततेवर परिणाम करू शकतात. तुमच्या गरजांसाठी योग्य निवडण्यासाठी हे फरक समजून घेणे महत्त्वाचे आहे.
हा लेख हॅशमॅप आणि हॅशटेबल मधील मुख्य भेदांचा शोध घेतो, त्यांची कार्यक्षमता, कार्यक्षमता आणि थ्रेड नसलेल्या अनुप्रयोगांसाठी उपयुक्तता शोधतो. शेवटपर्यंत, तुमच्या विशिष्ट वापर प्रकरणात कोणती डेटा रचना वापरायची याची तुम्हाला स्पष्ट कल्पना असेल.
आज्ञा | वर्णन |
---|---|
HashMap.put() | हॅशमॅपमध्ये की-व्हॅल्यू जोडी समाविष्ट करते. शून्य की आणि मूल्यांना अनुमती देते. |
Hashtable.put() | हॅशटेबलमध्ये की-व्हॅल्यूची जोडी समाविष्ट करते. शून्य की किंवा मूल्यांना अनुमती देत नाही. |
System.nanoTime() | चालू असलेल्या Java व्हर्च्युअल मशीनच्या उच्च-रिझोल्यूशन टाइम स्रोताचे वर्तमान मूल्य नॅनोसेकंदमध्ये मिळवते. |
try { ... } catch (NullPointerException e) | कोड कार्यान्वित करण्याचा प्रयत्न करते आणि कोणतेही NullPointerExceptions पकडते, केस हाताळते जेथे Hashtable.put() शून्य मूल्यांसह कॉल केले जाते. |
HashMap.get() | हॅशमॅपवरून निर्दिष्ट कीशी संबंधित मूल्य पुनर्प्राप्त करते. |
Hashtable.get() | हॅशटेबलमधून निर्दिष्ट कीशी संबंधित मूल्य पुनर्प्राप्त करते. |
हॅशमॅप आणि हॅशटेबल अंमलबजावणीमध्ये खोलवर जा
प्रथम स्क्रिप्ट दरम्यान थेट तुलना प्रदान करते आणि जावा मध्ये. स्क्रिप्ट आवश्यक वर्ग आयात करून आणि दोन्ही डेटा स्ट्रक्चर्सची उदाहरणे तयार करून सुरू होते. ए की-व्हॅल्यू जोड्यांसह त्वरित आणि पॉप्युलेट केले जाते. त्याचप्रमाणे, ए १ तयार आणि लोकसंख्या आहे. ही स्क्रिप्ट नंतर शून्य मूल्ये हाताळण्यात मूलभूत फरक दर्शवते. समस्यांशिवाय शून्य मूल्ये घालण्यास अनुमती देते, तर फेकतो अ जर शून्य की किंवा मूल्ये जोडण्याचा प्रयत्न केला असेल. द ७ हे वर्तन स्पष्ट करण्यासाठी ब्लॉक्स वापरले जातात. या दोन डेटा स्ट्रक्चर्समधून निवड करताना शून्य मूल्यांचा विचार केव्हा आणि का केला जातो हे स्क्रिप्ट विकसकांना समजण्यास मदत करते.
दुसरी स्क्रिप्ट कामगिरी चाचणीवर लक्ष केंद्रित करते आणि थ्रेड नसलेल्या वातावरणात. हे दोन्ही नकाशे सुरू करून आणि वापरून दशलक्ष की-व्हॅल्यू जोड्या घालण्यासाठी लागणारा वेळ मोजून सुरू होते. . हे उच्च-रिझोल्यूशन वेळ मापन ऑपरेशनसाठी लागणारा अचूक वेळ कॅप्चर करण्यात मदत करते. परिणाम कन्सोलवर मुद्रित केले जातात, सापेक्ष कार्यप्रदर्शन दर्शवितात. स्क्रिप्ट दोन्ही डेटा स्ट्रक्चर्समधील कीच्या समान संचासाठी पुनर्प्राप्ती वेळ देखील मोजते. या वेळेची तुलना करून, थ्रेड नसलेल्या अनुप्रयोगांमध्ये कोणती डेटा रचना अधिक चांगली कामगिरी करते हे डेव्हलपर मोजू शकतात. ही स्क्रिप्ट कार्यप्रदर्शन ट्यूनिंग आणि संबंधित ओव्हरहेड समजून घेण्यासाठी विशेषतः उपयुक्त आहे १ त्याच्या समक्रमित पद्धतींमुळे.
हॅशमॅप आणि हॅशटेबलची तुलना करणे: मुख्य फरक आणि वापर प्रकरणे
तुलना करण्यासाठी Java अंमलबजावणी
import java.util.HashMap;
import java.util.Hashtable;
public class MapComparison {
public static void main(String[] args) {
// Creating a HashMap
HashMap<String, String> hashMap = new HashMap<>();
hashMap.put("1", "One");
hashMap.put("2", "Two");
hashMap.put("3", "Three");
// Creating a Hashtable
Hashtable<String, String> hashtable = new Hashtable<>();
hashtable.put("A", "Apple");
hashtable.put("B", "Banana");
hashtable.put("C", "Cherry");
// Displaying the HashMap
System.out.println("HashMap: " + hashMap);
// Displaying the Hashtable
System.out.println("Hashtable: " + hashtable);
// Checking for null values
try {
hashMap.put(null, "NullValue");
System.out.println("HashMap allows null values: " + hashMap);
} catch (NullPointerException e) {
System.out.println("HashMap does not allow null values");
}
try {
hashtable.put(null, "NullValue");
System.out.println("Hashtable allows null values: " + hashtable);
} catch (NullPointerException e) {
System.out.println("Hashtable does not allow null values");
}
}
}
हॅशमॅप वि. हॅशटेबल: सिंगल-थ्रेडेड वातावरणातील कामगिरी
नॉन-थ्रेडेड ऍप्लिकेशन्ससाठी Java कार्यप्रदर्शन चाचणी
१
हॅशमॅप आणि हॅशटेबल: सिंक्रोनाइझेशन आणि थ्रेड सुरक्षा
मधील मुख्य फरकांपैकी एक आणि सिंक्रोनाइझेशन आणि थ्रेड सुरक्षिततेसाठी त्यांचा दृष्टीकोन आहे. सिंक्रोनाइझ केले आहे, याचा अर्थ ते थ्रेड-सेफ आहे आणि एकाचवेळी समस्या निर्माण न करता एकाधिक थ्रेडमध्ये सामायिक केले जाऊ शकते. हे सिंक्रोनाइझेशन त्याच्या बहुतेक पद्धती सिंक्रोनाइझ करून प्राप्त केले जाते, जे कोणत्याही वेळी हॅशटेबलमध्ये फक्त एक थ्रेड प्रवेश करू शकतो याची खात्री करते. तथापि, हे लॉकिंग यंत्रणा, मेकिंगमुळे कार्यप्रदर्शन ओव्हरहेड देखील सादर करते १ च्या तुलनेत हळू सिंगल-थ्रेडेड परिस्थितींमध्ये.
याउलट, समक्रमित नाही आणि म्हणून थ्रेड-सुरक्षित नाही. जर ए एकाच वेळी अनेक थ्रेड्सद्वारे प्रवेश केला जातो, डेटा विसंगती आणि शर्यतीच्या परिस्थितीचा धोका असतो. बनवण्यासाठी ए थ्रेड-सेफ, विकसक वापरू शकतात Collections.synchronizedMap() ते सिंक्रोनाइझ केलेल्या नकाशामध्ये गुंडाळण्यासाठी, किंवा ते वापरू शकतात Java 1.5 मध्ये सादर केलेला वर्ग, जो नकाशाच्या विविध भागांमध्ये समवर्ती प्रवेशास अनुमती देऊन उत्तम कार्यप्रदर्शन प्रदान करतो. हे करते समवर्ती अनुप्रयोगांसाठी अधिक कार्यक्षम निवड.
- हॅशमॅप आणि हॅशटेबलमधील मुख्य फरक काय आहे?
- सिंक्रोनाइझ केलेले नाही आणि शून्य की आणि मूल्यांना अनुमती देते समक्रमित आहे आणि शून्य की किंवा मूल्यांना अनुमती देत नाही.
- सिंगल-थ्रेडेड वातावरणात कोणता वेगवान आहे?
- सिंक्रोनाइझेशन ओव्हरहेडच्या कमतरतेमुळे एकल-थ्रेडेड वातावरणात सामान्यतः वेगवान असते.
- तुम्ही हॅशमॅप थ्रेड-सेफ कसा बनवू शकता?
- वापरून लपेटणे किंवा वापरून .
- हॅशटेबल शून्य की किंवा मूल्ये संचयित करू शकते?
- नाही, शून्य की किंवा मूल्यांना अनुमती देत नाही आणि फेकून देईल a प्रयत्न केला तर.
- तुम्ही Hashtable over HashMap कधी वापरावे?
- वापरा जेव्हा थ्रेड सुरक्षितता आवश्यक असते आणि तुम्हाला सिंक्रोनाइझेशनच्या ओव्हरहेड कामगिरीबद्दल चिंता नसते.
- ConcurrentHashMap हॅशटेबलसाठी एक चांगला पर्याय आहे का?
- होय, च्या तुलनेत चांगले समरूपता आणि कार्यप्रदर्शन प्रदान करते .
- हॅशमॅप थ्रेड-सेफ का नाही?
- सिंगल-थ्रेडेड परिस्थितींसाठी डिझाइन केलेले आहे आणि सिंक्रोनाइझेशन यंत्रणा समाविष्ट करत नाही.
- हॅशमॅप आणि हॅशटेबल टक्कर कसे हाताळतात?
- दोन्ही आणि चेनिंग वापरून टक्कर हाताळा, जिथे प्रत्येक बादलीमध्ये नोंदींची लिंक केलेली सूची असते.
हॅशमॅप आणि हॅशटेबल की-व्हॅल्यू जोड्या संग्रहित करण्यासाठी समान हेतू देतात परंतु सिंक्रोनाइझेशन आणि कार्यप्रदर्शनासाठी त्यांच्या दृष्टिकोनामध्ये लक्षणीय भिन्न आहेत. थ्रेड नसलेल्या अनुप्रयोगांसाठी हॅशमॅपला त्याची गती आणि शून्य मूल्यांसह लवचिकता यामुळे प्राधान्य दिले जाते. याउलट, हॅशटेबल थ्रेड-सेफ ऑपरेशनसाठी योग्य आहे परंतु कार्यक्षमतेच्या किंमतीवर. हे फरक समजून घेऊन, विकासक त्यांच्या विशिष्ट आवश्यकतांच्या आधारे कोणती डेटा रचना वापरायची यावर माहितीपूर्ण निर्णय घेऊ शकतात.