मुझे यह तब मिलता है जब मैं toString
एक फ़ंक्शन कॉल से प्राप्त एक वस्तु पर कॉल करता हूं। मुझे पता है कि इस स्ट्रिंग में ऑब्जेक्ट का प्रकार एन्कोडेड है, लेकिन मुझे नहीं पता कि इसे कैसे पढ़ना है।
इस प्रकार के एन्कोडिंग को क्या कहा जाता है?
मुझे यह तब मिलता है जब मैं toString
एक फ़ंक्शन कॉल से प्राप्त एक वस्तु पर कॉल करता हूं। मुझे पता है कि इस स्ट्रिंग में ऑब्जेक्ट का प्रकार एन्कोडेड है, लेकिन मुझे नहीं पता कि इसे कैसे पढ़ना है।
इस प्रकार के एन्कोडिंग को क्या कहा जाता है?
जवाबों:
[Ljava.lang.Object;
का नाम है Object[].class
, java.lang.Class
सरणी के वर्ग का प्रतिनिधित्व करने के लिए Object
।
नामकरण योजना में प्रलेखित है Class.getName()
:
यदि यह वर्ग ऑब्जेक्ट एक संदर्भ प्रकार का प्रतिनिधित्व करता है जो कि एक सरणी प्रकार नहीं है, तो जावा भाषा विनिर्देश ( .113.1 ) द्वारा निर्दिष्ट वर्ग का द्विआधारी नाम वापस आ जाता है ।
यदि यह वर्ग ऑब्जेक्ट एक आदिम प्रकार का प्रतिनिधित्व करता है या
void
, तो लौटाया गया नाम आदिम प्रकार के अनुरूप जावा भाषा का कीवर्ड है याvoid
।यदि यह क्लास ऑब्जेक्ट सरणियों के एक वर्ग का प्रतिनिधित्व करता है, तो नाम का आंतरिक रूप
'['
एरेस्ट नेस्टिंग की गहराई का प्रतिनिधित्व करने वाले एक या अधिक वर्णों से पहले के तत्व प्रकार के नाम से बना होता है । तत्व प्रकार के नामों की एन्कोडिंग इस प्रकार है:Element Type Encoding boolean Z byte B char C double D float F int I long J short S class or interface Lclassname;
तुम्हारा उस सूची में अंतिम है। यहाँ कुछ उदाहरण हैं:
// xxxxx varies
System.out.println(new int[0][0][7]); // [[[I@xxxxx
System.out.println(new String[4][2]); // [[Ljava.lang.String;@xxxxx
System.out.println(new boolean[256]); // [Z@xxxxx
इस प्रारूप में toString()
सरणियों पर विधि क्यों लौटती String
है इसका कारण यह है कि सरणियाँ @Override
उस विधि से विरासत में नहीं मिली हैं Object
, जो निम्नानुसार निर्दिष्ट है:
toString
वर्ग के लिए विधिObject
@ एक स्ट्रिंग वर्ग जो की वस्तु एक उदाहरण, पर हस्ताक्षर चरित्र `है के नाम से मिलकर ', और वस्तु की हैश कोड की अहस्ताक्षरित हेक्साडेसिमल प्रतिनिधित्व देता है। दूसरे शब्दों में, यह विधि एक मान के बराबर स्ट्रिंग लौटाती है:getClass().getName() + '@' + Integer.toHexString(hashCode())
नोट : आपtoString()
उपरोक्त विनिर्देशन का पालन करने के लिए किसी भी मनमानी वस्तुपर भरोसा नहीं कर सकते, क्योंकि वे@Override
कुछ और वापस करने के लिएकर सकते हैं (और आमतौर पर)। एक मनमानी वस्तु के प्रकार का निरीक्षण करने का अधिक विश्वसनीय तरीका उसgetClass()
परआह्वानकरना है (एकfinal
विधिजिसेविरासत में मिली हैObject
) और फिरलौटी हुईवस्तुको दर्शाती हैClass
। आदर्श रूप से, हालांकि, एपीआई को ऐसे डिज़ाइन किया जाना चाहिए था कि प्रतिबिंब आवश्यक नहीं है ( प्रभावी जावा 2 संस्करण देखें, आइटम 53: प्रतिबिंब के लिए इंटरफेस को प्राथमिकता दें )।
toString
सरणियों के लिए अधिक "उपयोगी" परjava.util.Arrays
toString
आदिम सरणियों के लिए अतिभार प्रदान करता है और Object[]
। ऐसा भी है deepToString
कि आप नेस्टेड सरणियों के लिए उपयोग करना चाह सकते हैं।
यहाँ कुछ उदाहरण हैं:
int[] nums = { 1, 2, 3 };
System.out.println(nums);
// [I@xxxxx
System.out.println(Arrays.toString(nums));
// [1, 2, 3]
int[][] table = {
{ 1, },
{ 2, 3, },
{ 4, 5, 6, },
};
System.out.println(Arrays.toString(table));
// [[I@xxxxx, [I@yyyyy, [I@zzzzz]
System.out.println(Arrays.deepToString(table));
// [[1], [2, 3], [4, 5, 6]]
वहाँ भी Arrays.equals
और Arrays.deepEquals
है कि उनके तत्वों, कई अन्य सरणी से संबंधित उपयोगिता तरीकों में से एक द्वारा सरणी समानता तुलना करते हैं।