1. StringTokenizer
वर्ग
आणि आता आणखी काही सामान्य परिस्थिती ज्यामध्ये स्ट्रिंग्ससह काम करणे समाविष्ट आहे. तुम्ही स्ट्रिंगला अनेक भागांमध्ये कसे विभाजित कराल? हे करण्याचे अनेक मार्ग आहेत.
split()
पद्धत
स्ट्रिंगला अनेक भागांमध्ये विभाजित करण्याचा पहिला मार्ग म्हणजे पद्धत वापरणे split()
. विशिष्ट सीमांकन स्ट्रिंग परिभाषित करणारी नियमित अभिव्यक्ती वितर्क म्हणून पास करणे आवश्यक आहे. जावा मल्टीथ्रेडिंग क्वेस्टमध्ये रेग्युलर एक्सप्रेशन म्हणजे काय ते तुम्ही शिकाल .
उदाहरण:
कोड | परिणाम |
---|---|
|
परिणाम तीन स्ट्रिंगचा अॅरे असेल:
|
सोपा, परंतु कधीकधी हा दृष्टीकोन अतिरेक असतो. जर तेथे बरेच परिसीमक असतील (उदाहरणार्थ, रिक्त स्थान, नवीन रेखा वर्ण, टॅब, पूर्णविराम), तर तुम्हाला त्याऐवजी जटिल नियमित अभिव्यक्ती तयार करावी लागेल. ते वाचणे कठीण आहे आणि म्हणून सुधारणे कठीण आहे.
StringTokenizer
वर्ग
Java मध्ये एक विशेष वर्ग आहे ज्यांचे संपूर्ण कार्य स्ट्रिंगला सबस्ट्रिंगमध्ये विभाजित करणे आहे.
हा वर्ग रेग्युलर एक्सप्रेशन वापरत नाही: त्याऐवजी, तुम्ही डिलिमिटर असलेल्या स्ट्रिंगमध्ये पास करता. या पध्दतीचा फायदा असा आहे की तो संपूर्ण स्ट्रिंग एकाच वेळी तुकडे करत नाही, तर त्याऐवजी एका वेळी एक पायरी सुरुवातीपासून शेवटपर्यंत सरकतो.
वर्गात कन्स्ट्रक्टर आणि दोन महत्त्वाच्या पद्धती आहेत. आम्ही कन्स्ट्रक्टरला एक स्ट्रिंग पास करतो जी आम्ही भागांमध्ये विभाजित करतो आणि एक स्ट्रिंग ज्यामध्ये सीमांकित वर्णांचा संच असतो.
पद्धती | वर्णन |
---|---|
|
पुढील सबस्ट्रिंग मिळवते |
|
अधिक सबस्ट्रिंग आहेत का ते तपासते. |
हा वर्ग कसा तरी स्कॅनर वर्गाची आठवण करून देणारा आहे, ज्यामध्ये पद्धती देखील nextLine()
आहेत hashNextLine()
.
आपण StringTokenizer
या आदेशासह ऑब्जेक्ट तयार करू शकता:
StringTokenizer name = new StringTokenizer(string, delimiters);
string
स्ट्रिंग कुठे भागांमध्ये विभागली जाईल. आणि delimiters
एक स्ट्रिंग आहे, आणि त्यातील प्रत्येक वर्ण हा परिसीमक मानला जातो. उदाहरण:
कोड | कन्सोल आउटपुट |
---|---|
|
|
लक्षात ठेवा की स्ट्रिंगमधील प्रत्येक वर्ण कन्स्ट्रक्टरला दुसरी स्ट्रिंग म्हणून पास केला जातो StringTokenizer
तो विभाजक मानला जातो.
2. String.format()
पद्धत आणि StringFormatter
वर्ग
स्ट्रिंग वर्गाची आणखी एक मनोरंजक पद्धत आहे format()
.
समजा तुमच्याकडे डेटा साठवणारे विविध व्हेरिएबल्स आहेत. तुम्ही त्यांना एका ओळीत स्क्रीनवर कसे प्रदर्शित कराल? उदाहरणार्थ, आमच्याकडे काही डेटा (डावा स्तंभ) आणि इच्छित आउटपुट (उजवा स्तंभ):
कोड | कन्सोल आउटपुट |
---|---|
|
|
तुमचा कोड कदाचित असे काहीतरी दिसेल:
कार्यक्रम कोड |
---|
|
असा कोड फारसा वाचनीय नाही. आणि जर व्हेरिएबलची नावे मोठी असतील तर कोड आणखी कठीण होईल:
कार्यक्रम कोड |
---|
|
फार वाचनीय नाही, आहे का?
परंतु वास्तविक-जगातील प्रोग्राममध्ये ही एक सामान्य परिस्थिती आहे, म्हणून मी तुम्हाला हा कोड अधिक सोप्या आणि अधिक संक्षिप्तपणे लिहिण्याच्या मार्गाबद्दल सांगू इच्छितो.
String.format
स्ट्रिंग क्लासमध्ये एक स्थिर format()
पद्धत आहे: ती तुम्हाला डेटासह स्ट्रिंग एकत्र करण्यासाठी नमुना निर्दिष्ट करू देते. कमांडचे सामान्य स्वरूप खालीलप्रमाणे आहे:
String name = String.format(pattern, parameters);
उदाहरण:
कोड | परिणाम |
---|---|
|
|
|
|
|
|
पद्धतीचा पहिला पॅरामीटर एक फॉरमॅट स्ट्रिंग आहे ज्यामध्ये तुम्हाला डेटा घालण्याची आवश्यकता असलेल्या ठिकाणी फॉरमॅट स्पेसिफायर (जसे की आणि ) format()
नावाच्या विशेष वर्णांसह सर्व इच्छित मजकूर समाविष्ट आहे .%d
%s
पॅरामीटर सूचीमधील फॉरमॅट स्ट्रिंगला फॉलो करणार्या पॅरामीटर्ससह पद्धत या आणि फॉरमॅट स्पेसिफायरला पुनर्स्थित format()
करते %s
. %d
जर आपल्याला स्ट्रिंग घालायची असेल तर आपण लिहू %s
. जर आपल्याला संख्या घालायची असेल, तर स्वरूप निर्दिष्टकर्ता आहे %d
. उदाहरण:
कोड | परिणाम |
---|---|
|
s च्या समान आहे"a=1, b=4, c=3" |
फॉरमॅट स्ट्रिंगमध्ये वापरल्या जाऊ शकणार्या फॉरमॅट स्पेसिफायर्सची ही एक छोटी सूची आहे:
विनिर्देशक | अर्थ |
---|---|
|
String |
|
interger: byte , short , int ,long |
|
वास्तविक संख्या: float ,double |
|
boolean |
|
char |
|
Date |
|
% वर्ण |
हे स्पेसिफायर्स डेटाचा प्रकार दर्शवतात, परंतु असे स्पेसिफायर्स देखील आहेत जे डेटाचा क्रम दर्शवतात. त्याच्या संख्येनुसार युक्तिवाद मिळविण्यासाठी (क्रमांक एक पासून सुरू होते), तुम्हाला " " ऐवजी " " लिहावे लागेल. उदाहरण:%1$d
%d
कोड | परिणाम |
---|---|
|
s च्या समान आहे"a=13, b=12, c=11" |
%3$d
तिसरा युक्तिवाद मिळेल, %2$d
दुसरा युक्तिवाद मिळेल आणि %d
पहिला युक्तिवाद मिळेल. %s
आणि फॉरमॅट स्पेसिफायर्स हे किंवा %d
सारख्या स्पेसिफायर्सची पर्वा न करता वितर्कांचा संदर्भ घेतात%3$d
%2$s
3. स्ट्रिंग पूल
StringPool
स्ट्रिंग लिटरल म्हणून कोडमध्ये निर्दिष्ट केलेली प्रत्येक स्ट्रिंग प्रोग्राम चालू असताना मेमरीच्या क्षेत्रात संग्रहित केली जाते . StringPool
स्ट्रिंग संचयित करण्यासाठी एक विशेष अॅरे आहे. स्ट्रिंग स्टोरेज ऑप्टिमाइझ करणे हा त्याचा उद्देश आहे:
प्रथम, कोडमध्ये निर्दिष्ट केलेल्या स्ट्रिंग्स कुठेतरी संग्रहित केल्या पाहिजेत, बरोबर? कोडमध्ये कमांड्स असतात, परंतु डेटा (विशेषत: मोठ्या स्ट्रिंग्स) कोडपासून स्वतंत्रपणे मेमरीमध्ये संग्रहित करणे आवश्यक आहे. कोडमध्ये फक्त स्ट्रिंग ऑब्जेक्ट्सचे संदर्भ दिसतात.
दुसरे, सर्व समान स्ट्रिंग अक्षरे फक्त एकदाच मेमरीमध्ये संग्रहित करणे आवश्यक आहे. आणि ते फक्त कसे कार्य करते. जेव्हा तुमचा वर्ग कोड Java मशीनद्वारे लोड केला जातो, तेव्हा सर्व स्ट्रिंग लिटरल्स StringPool
आधीपासून नसल्यास त्यात जोडले जातात. जर ते आधीच तेथे असतील, तर आम्ही फक्त वरून स्ट्रिंग संदर्भ वापरतो StringPool
.
त्यानुसार, तुम्ही String
तुमच्या कोडमधील अनेक व्हेरिएबल्सना समान शब्दशः नियुक्त केल्यास, या व्हेरिएबल्समध्ये समान संदर्भ असेल. शाब्दिक फक्त एकदाच जोडले जाईल StringPool
. इतर सर्व प्रकरणांमध्ये, कोडला आधीपासून लोड केलेल्या स्ट्रिंगचा संदर्भ मिळेल StringPool
.
ते कसे कार्य करते ते येथे आहे:
कोड | StringPool सह काम |
---|---|
|
|
म्हणूनच a
आणि b
व्हेरिएबल्स समान संदर्भ संग्रहित करतील.
intern()
पद्धत
आणि सर्वात चांगला भाग असा आहे की तुम्ही प्रोग्राममध्ये कोणतीही स्ट्रिंग जोडू शकता StringPool
. हे करण्यासाठी, तुम्हाला फक्त String
व्हेरिएबलची intern()
पद्धत कॉल करण्याची आवश्यकता आहे.
पद्धत आधीपासून नसल्यास intern()
स्ट्रिंगमध्ये जोडेल आणि मधील स्ट्रिंगचा संदर्भ देईल .StringPool
StringPool
StringPool
पद्धत वापरून दोन समान स्ट्रिंग जोडल्या गेल्यास intern()
, पद्धत समान संदर्भ देते. हे संदर्भानुसार स्ट्रिंग्सची तुलना करण्यासाठी वापरले जाऊ शकते. उदाहरण:
कोड | नोंद |
---|---|
|
|
|
|
तुम्ही ही पद्धत सहसा वापरण्याची शक्यता नाही, परंतु लोकांना मुलाखतींमध्ये याबद्दल विचारणे आवडते . त्यामुळे न कळण्यापेक्षा त्याबद्दल जाणून घेणे चांगले.
GO TO FULL VERSION