1. की-वैल्यू पेयर का एक सेट।
जावा में, एक और दिलचस्प संग्रह (मोटे तौर पर बोलना) है Map
। कभी-कभी इस डेटा संरचना को शब्दकोश भी कहा जाता है।
यह Set
संग्रह के समान है, लेकिन यह तत्वों के सेट के बजाय तत्वों के "जोड़े" का एक सेट संग्रहीत करता है, प्रत्येक जोड़ी में Map
दो तत्व होते हैं: एक "कुंजी" और एक "मान"।
मान लीजिए कि आप चाहते हैं कि आपका कार्यक्रम कर्मचारियों के नाम और उनके वेतन, या आपके सहकर्मियों के नाम और उनकी उम्र को संग्रहित करे। तो आपको इस तरह की एक टेबल की आवश्यकता होगी:
नाम | आयु |
---|---|
ELON | 21 |
जेफ | 22 |
बिल | 48 |
ख़रगोश पालने का बाड़ा | ? |
प्रत्येक पंक्ति में कुछ मान होते हैं। हम नाम को जोड़ी की कुंजी के रूप में , और उम्र को जोड़ी के मान के रूप में संदर्भित करेंगे ।
इन जोड़ियों का पूरा सेट हमारा नक्शा ( Map
) है।
एक जोड़ी की कुंजी को छोड़कर कुछ भी हो सकता है null
। कुंजियाँ अद्वितीय होनी चाहिए: एक मानचित्र में दो समान कुंजियाँ नहीं हो सकतीं।
2. HashMap
वर्ग
वर्ग HashMap
सबसे लोकप्रिय प्रकार का Map
संग्रह है। एक ओर, यह हैशसेट के समान है और इसके सभी तरीके हैं। दूसरी ओर, यह एक सूची ( ArrayList
) की तरह है जो शब्दों (या कुछ और) को इसके सूचकांक के रूप में उपयोग कर सकता है।
आप HashMap
इस तरह एक बयान का उपयोग कर बना सकते हैं:
HashMap<KeyType, ValueType> name = new HashMap<KeyType, ValueType>();
KeyType
संग्रहीत जोड़े में कुंजियों का प्रकार कहाँ है, और संग्रह ValueType
में संग्रहीत जोड़े में मानों का प्रकार है।HashMap
कक्षा HashMap
में इस तरह के तरीके हैं:
तरीका | विवरण |
---|---|
|
( key , value ) जोड़ी को संग्रह में जोड़ता है |
|
कुंजी से जुड़ा मान लौटाता है। |
|
जांचता है कि संग्रह में कोई कुंजी मौजूद है या नहीं |
|
संग्रह में किसी मान के अस्तित्व की जाँच करता है |
|
संग्रह से एक तत्व निकालता है |
|
सभी तत्वों को हटाते हुए संग्रह को साफ़ करता है |
|
संग्रह में कुंजी-मूल्य जोड़े की संख्या लौटाता है |
|
संग्रह में चाबियों का सेट लौटाता है |
|
संग्रह के तत्वों से युक्त एक सेट लौटाता है |
|
संग्रह में Set सभी जोड़े ( ) का एक सेट ( ) लौटाता है ।Map.Entry |
ए में तत्वों को जोड़नाHashMap
put()
विधि का उपयोग करके जोड़े के रूप में तत्वों को मानचित्र में जोड़ा जाता है । कुंजी को पहले तर्क के रूप में पारित किया जाता है, और मान को दूसरे के रूप में पारित किया जाता है।
HashMap<String, Integer> map = new HashMap<String, Integer>();
map.put("Elon", 21);
map.put("Jeff", 22);
map.put("Bill", 48);
map.put("Warren", null);
की-वैल्यू जोड़ी जोड़ते समय, यदि संग्रह में कुंजी पहले से मौजूद है, तो पुराने मान को नए मान से बदल दिया जाता है।
यह व्यवहार HashMap
एक सरणी या सूची की तरह बनाता है जिसका सूचकांक String
संख्या के बजाय शब्द ( ) हैं।
लगभग कोई भी प्रकार KeyType या ValueType हो सकता है। KeyType के लिए कुछ छोटी अतिरिक्त आवश्यकताएँ हैं, और जब आप Java Collections की खोज में संग्रहों का अधिक विस्तार से अध्ययन करेंगे, तो आप उनके बारे में जानेंगे।
3. a का उपसमुच्चय HashMap
: कुंजियों का समुच्चय
मान लीजिए कि हम केवल सभी प्रविष्टियों को HashMap
स्क्रीन पर प्रदर्शित करना चाहते हैं। हम इसे कैसे करते हैं? ऐसा करने के लिए, हमें यह जानने की आवश्यकता है कि HashMap
. यह कई मायनों में किया जा सकता है।
चाबियों पर लूप करना सबसे आसान तरीका है
HashMap
प्रविष्टियों को क्रमिक रूप से क्रमांकित नहीं किया जाता है, इसलिए काउंटर वाला लूप यहां काम नहीं करेगा। लेकिन हम विधि का उपयोग करके चाबियों का एक सेट प्राप्त कर सकते हैं keySet()
, और आप पहले से ही जानते हैं कि सेट पर पुनरावृति कैसे करें:
कोड | विवरण |
---|---|
|
map कुंजी से संबद्ध मान प्राप्त करें की कुंजियों पर लूप करें |
विधि keySet()
कुंजियों का एक सेट लौटाती है। आप इस सेट का दो तरह से उपयोग कर सकते हैं:
कॉम्पैक्ट नोटेशन | लंबा अंकन |
---|---|
|
|
4. की-वैल्यू पेयर पर लूपिंग
एक अधिक जटिल तरीका भी है: आप a को की-वैल्यू पेयर के सेटMap
में बदल सकते हैं , और फिर सेट के तत्वों पर लूप कर सकते हैं, जैसा कि हम पहले ही सीख चुके हैं।
संग्रह HashMap
में एक सहायक वर्ग है जो कुंजी-मूल्य जोड़े को संग्रहीत करता है। यह लगभग इस प्रकार दिखता है:
class Entry<KeyType, ValueType>
{
private KeyType key;
private ValueType value;
public KeyType getKey()
{
return this.key;
}
public ValueType getValue()
{
return this.value;
}
}
entrySet()
किसी वस्तु पर विधि को कॉल करने का परिणाम होगा :HashMap<KeyType, ValueType>
Set<Entry<KeyType, ValueType>>
Set<Entry<KeyType, ValueType>> name = map.entrySet();
यहां हमारे पास एक प्रकार के पैरामीटर के साथ सामान्य Set
वर्ग है, जो बदले में Entry
दो प्रकार के मापदंडों के साथ एक सामान्य प्रकार () है।
नौसिखियों के लिए इस बारे में भ्रमित होना बहुत आसान है। लेकिन एक बार जब आप इसका पता लगा लेते हैं, तो आप कोड लिख सकते हैं जैसे:
HashMap<String, Integer> map = new HashMap<String, Integer>();
map.put("Elon", 21);
map.put("Jeff", 22);
map.put("Bill", 48);
map.put("Warren", null);
Set<Map.Entry<String, Integer>> entries = map.entrySet();
for(Map.Entry<String, Integer> pair: entries)
{
String key = pair.getKey();
Integer value = pair.getValue();
System.out.println(key + " --> " + value);
}
उस ने कहा, इस कोड को थोड़ा सरल बनाया जा सकता है:
सबसे पहले, आप के लिए एक अलग चर बनाना छोड़ सकते हैं entries
और इसके बजाय entrySet()
सीधे for
लूप के अंदर विधि को कॉल कर सकते हैं:
for(Map.Entry<String, Integer> pair: map.entrySet())
{
String key = pair.getKey();
Integer value = pair.getValue();
System.out.println(key + " --> " + value);
}
दूसरा, आप हाल ही में पेश किए गए ऑपरेटर का उपयोग स्वचालित रूप से की-वैल्यू जोड़ीvar
के प्रकार का अनुमान लगाने के लिए कर सकते हैं :
for(var pair: map.entrySet())
{
String key = pair.getKey();
Integer value = pair.getValue();
System.out.println(key + " --> " + value);
}
बुरा नहीं, हुह?
5. ArrayList
और की तुलनाHashMap
एक HashMap
दृढ़ता से एक जैसा दिखता है ArrayList
जो स्ट्रिंग्स (या अन्य प्रकार) को इंडेक्स (कुंजी) के रूप में उपयोग करने की अनुमति देता है।
यदि आप Integer
for कुंजियों का उपयोग a में करते हैं HashMap
, तो यह a के समान और भी अधिक हो जाता है ArrayList
। आइए तुलना करें:
ArrayList <स्ट्रिंग> के साथ कोड | हैश मैप <पूर्णांक, स्ट्रिंग> के साथ कोड |
---|---|
|
|
GO TO FULL VERSION