c++ - assign `this` to `MyClass *instance`, `instance->member` is not referencing same memory as `this->member` -


मेरे सीपीपी कार्यान्वयन में मेरे पास है:

  स्थिर MyClass * उदाहरण;  

सभी युक्त स्कोप (घुंघराले {}) के बाहर आज़ादी से चलती है मैंने इसे nullptr करने के लिए भी आरंभ करने की कोशिश की है।

  शून्य MyClass :: myMethod () {instance = this; लॉग ("हैलो,% d,% d", wList, उदाहरण-> डब्लूएलआईएस);  

उपरोक्त लॉग सदस्य ऑब्जेक्ट पॉइंटर wList के लिए एक मनमाना स्थान दिखाता है, लेकिन उदाहरण उसी डेटा की ओर इशारा कर देना चाहिए जो कि यह करता है, और इसलिए वही wList , लेकिन यह नहीं है example-> wList अभी भी 0 है। यहां क्या हो रहा है?

के रूप में मार्क रोटोम ने टिप्पणी में नोट किया, आप एक संकेतक को प्रिंट करने के लिए % d फ़ॉर्मेट स्पेसिजर का उपयोग नहीं कर सकते हैं, आपको अपने कोड को पोर्टेबल होने के लिए % p का उपयोग करना होगा पॉइंटर्स के लिए % p के अलावा कुछ भी उपयोग करने के लिए तकनीकी रूप से अपरिभाषित व्यवहार है, लेकिन सभी संभावनाओं में आप देखेंगे कि यह 32-बिट सिस्टम पर ठीक काम करेगा।

हालांकि, 64-बिट सिस्टम पर, जिस पर मैं दांव लगाता हूं आप का उपयोग कर रहे हैं, यह ऊपर चल रही है संकेतक 8 बाइट्स हैं, लेकिन printf स्टैक के 4 बाइट्स को पढ़ने की कोशिश करता है, जब यह % d को देखता है दूसरा % d स्पेसिफायर के लिए, यह अगले 4 बाइट्स को पढ़ता है, जो सूचक के अन्य 4 बाइट्स हैं- यदि आप उस के लिए 0 देख रहे हैं, तो शायद इसका अर्थ है कि आपका पॉइंटर एक छोटे-एंडियन सिस्टम पर पहले 4 जीबी की मेमोरी (यानी इसका मान कुछ 0x00000000'xxxxxxxx जैसा था)। printf के पास दूसरे पॉइंटर से स्टैक पर 8 बाइट्स कभी भी नहीं पढ़ा जाता।

% p स्पेसिफिकर पोर्टेबल सभी प्लेटफॉर्म्स पर एक संकेतक छापता है, चाहे वे 32 बिट, 64 बिट, या किसी अन्य आकार के हों। इसका एक दुर्भाग्यपूर्ण परिणाम यह है कि सटीक आउटपुट प्रारूप कार्यान्वयन-परिभाषित है, जिसका अर्थ है कि यह सिस्टम के बीच में परिवर्तन कर सकता है और करता है। कुछ सिस्टम एक अग्रणी 0x या 0x का उपयोग कर सकते हैं, जबकि अन्य में कोई भी उपसर्ग नहीं हो सकता है और केवल कच्चे हेक्स मूल्य को प्रिंट कर सकते हैं कुछ लोगों को 0 के साथ बाएं पैड हो सकता है, और अन्य शायद नहीं।

यदि आप सटीक आउटपुट को नियंत्रित करना चाहते हैं, तो आप अपनी पसंद के प्रारूप का उपयोग कर सकते हैं (जैसे % 08x या % 016llx ) जब तक आप उस विनिर्देशक के लिए उचित सूचक डालते हैं उदाहरण के लिए, यहां बताया गया है कि 32- और 64-बिट सिस्टमों पर आप कैसे करेंगे:

  printf ("0x% 08x \ n", (अहस्ताक्षरित int) (uintptr_t) myPointer); // 32-बिट प्रिंटफ़ ("0x% 016llx \ n", (अहस्ताक्षरित लंबे समय तक) (uintptr_t) myPointer); दो बार कास्टिंग करने का कारण नकली संकलक चेतावनियों से बचने का कारण है, क्योंकि कुछ कंपलर शिकायत करेंगे कि यदि आप एक सूचक प्रकार से एक पूर्णांक प्रकार में डालेंगे जो कि इसकी गारंटी नहीं है एक सूचक रखने के लिए पर्याप्त रूप से बड़ा हो। 


Comments

Popular posts from this blog

GO: Serve static pages -

java - how to parse a JSON string into ObjectNode in Jackson? -

objective c - How to open front/back camera at the same time in iOS developing? -