1. तुलना
प्रोग्रामर को हर समय एक दूसरे के साथ विभिन्न चरों की तुलना करने की आवश्यकता होती है। लेकिन, जैसा कि आप पहले ही देख चुके हैं, सब कुछ इतना आसान नहीं है।
पूर्णांकों की तुलना करना बहुत आसान है — आप बस उपयोग करें ==
और आपका काम हो गया। वास्तविक संख्याओं की तुलना करने के लिए , आपको उनके अंतर (या बल्कि, अंतर के निरपेक्ष मान) की तुलना किसी बहुत छोटी संख्या से करनी होगी।
तार की तुलना करना और भी कठिन है। इन सबसे ऊपर, यह इसलिए है क्योंकि तार वस्तुएँ हैं। क्या अधिक है, प्रोग्रामर अक्सर स्थिति के आधार पर स्ट्रिंग तुलना को थोड़ा अलग करना चाहते हैं।
2. मेमोरी को कैसे व्यवस्थित किया जाता है
जैसा कि आप पहले ही देख चुके हैं, स्ट्रिंग्स को पूर्णांकों और वास्तविक संख्याओं की तुलना में स्मृति में अलग तरीके से संग्रहीत किया जाता है:
स्ट्रिंग्स को स्टोर करने के लिए मेमोरी के दो ब्लॉक का उपयोग किया जाता है: एक ब्लॉक टेक्स्ट को स्टोर करता है (इसका आकार टेक्स्ट के आकार पर निर्भर करता है) जबकि दूसरा ब्लॉक (4 बाइट्स) पहले ब्लॉक के पते को स्टोर करता है।
हालांकि एक अनुभवी प्रोग्रामर कुछ ऐसा कहेगा जैसे " वैरिएबल किसी ऑब्जेक्ट String
str
के संदर्भ को स्टोर करता है ।String
3. एक स्ट्रिंग के संदर्भ निर्दिष्ट करना
इस दृष्टिकोण के लाभ तब स्पष्ट हो जाते हैं जब आपको एक स्ट्रिंग वैरिएबल को दूसरे स्ट्रिंग वैरिएबल को असाइन करने की आवश्यकता होती है। उदाहरण:
String text = "This is a very important message";
String message = text;
और परिणामस्वरूप स्मृति में क्या होगा:

इस प्रकार के असाइनमेंट ऑपरेशन के बाद, String
ऑब्जेक्ट वहीं रहता है जहां वह था, और केवल उसका पता (ऑब्जेक्ट का संदर्भ) message
चर में कॉपी किया जाता है।
4. संदर्भों और वस्तुओं के साथ कार्य करना
String
लेकिन यदि आप एक स्ट्रिंग को अपरकेस (कैपिटल लेटर) में बदलने का निर्णय लेते हैं, तो जावा मशीन सब कुछ ठीक करती है: आप दो वस्तुओं के साथ समाप्त हो जाएंगे , text
और message
चर संदर्भों को संग्रहीत करेंगे, प्रत्येक अपनी वस्तु के लिए।
उदाहरण:
String text = "This is a very important message";
String message = text.toUpperCase();
और परिणामस्वरूप स्मृति में क्या होगा:
कृपया ध्यान दें कि toUpperCase()
विधि उस स्ट्रिंग को नहीं बदलती जिस पर इसे कहा जाता है। इसके बजाय, यह एक नई स्ट्रिंग (नई वस्तु) बनाता है और इसका संदर्भ देता है।
कैसे एक और भी दिलचस्प उदाहरण के बारे में। मान लें कि आप किसी ऑब्जेक्ट को स्ट्रिंग पास करने का निर्णय लेते हैं Scanner
(ताकि वह स्ट्रिंग से मान पढ़ सके)।
उदाहरण:
String text = "10 20 40 80";
Scanner console = new Scanner(text);
int a = console.nextInt();
int b = console.nextInt();
आप इस बारे में अधिक जान सकते हैं कि Scanner
कक्षा यहां कैसे काम करती है ।
इस तरह यह सब स्मृति में संग्रहीत किया जाएगा:
इस मामले में, एक String
वस्तु स्मृति में बनी रहती है जैसे वह थी - केवल इसके संदर्भों को पास किया जाता है और चर में संग्रहीत किया जाता है।
5. String
वस्तुओं के संदर्भों की तुलना करना
और अंत में, हम मज़ेदार हिस्से तक पहुँच गए हैं: स्ट्रिंग तुलना।
स्ट्रिंग चर की तुलना करने के लिए आप दो ऑपरेटर का उपयोग कर सकते हैं: ==
(बराबर) और !=
(बराबर नहीं)। आप "से अधिक", "से कम", या "से अधिक या बराबर" ऑपरेटरों का उपयोग नहीं कर सकते - संकलक इसे अनुमति नहीं देगा।
लेकिन यहां एक दिलचस्प सूक्ष्मता है: वास्तव में स्ट्रिंग चर में क्या संग्रहीत होता है? यह सही है: वस्तुओं के पते (संदर्भ)। और इन पतों की तुलना की जाएगी:
String text = "Hi";
String message = text;
String s1 = text.toUpperCase();
String s2 = text.toUpperCase();
यहाँ स्मृति में क्या होगा:
और वेरिएबल्स एक ही ऑब्जेक्ट को संदर्भित करते हैं (पता स्टोर करें) message
। text
लेकिन s1
और s2
चर उन वस्तुओं के संदर्भों को संग्रहीत करते हैं जो बहुत समान लेकिन विशिष्ट हैं।
और यदि आप कोड में इन 4 वेरिएबल्स की तुलना करते हैं, तो आपको निम्न परिणाम मिलते हैं:
कोड | कंसोल आउटपुट |
---|---|
|
|
GO TO FULL VERSION