मैं एक अजीब समस्या में भाग रहा हूं, मैं कुछ हद तक ट्रैक करने में सक्षम हूं लेकिन मुझे अभी भी कारण दिखाई नहीं दे रहा है। शायद यहां कोई व्यक्ति कुछ प्रकाश डाल सकता है?एम्बेडेड प्लेटफ़ॉर्म पर थ्रेड क्लास मेमोरी आवंटन विषमता
मैं VxWorks 5.5 के शीर्ष PPCgnu604 toolchain के साथ C++ के विकास पर पॉवर प्रोसेसर पर चल रहा हूँ।
मैं बहुत की तरह एक वर्ग है:
class MyClass
{
public:
void run(void);
private:
CommandMesssageClass command;
StatusMessageClass status;
};
जब मेरे आवेदन शुरू कर दिया है, यह गतिशील MyClass का एक उदाहरण का आवंटन और एक धागा अपनी "रन" समारोह की ओर इशारा करते अंडे जाएगा। अनिवार्य रूप से यह केवल आदेशों के लिए मतदान करता है और रसीद पर, स्थिति वापस जारी करेगा।
ध्यान दें कि यह कक्षा का एक कटा हुआ संस्करण है। ब्रेवटी के लिए कई अन्य विधियां और चर छोड़ दिए गए हैं।
मुद्दा मैं देख रहा हूँ जब दोनों आदेश और स्थिति संदेश निजी वर्ग के सदस्यों के रूप में परिभाषित कर रहे हैं मैं इस तथ्य कोई गतिशील स्मृति आवंटन होना चाहिए के बावजूद स्मृति में उपलब्ध बाइट्स में एक परिवर्तन हो जाएगा है। यह महत्वपूर्ण है क्योंकि यह एक निर्धारक और दर-सुरक्षित प्रक्रिया होने की आवश्यकता है।
अगर मैं एक या एक से रन समारोह में संदेश घोषणाओं के दोनों ले जाते हैं, यह कोई अतिरिक्त आवंटन के साथ ठीक काम करता है!
मैं सी ++ घोषणाओं और स्मृति आवंटन की मेरी समझ में कुछ मौलिक लापता होना चाहिए। मेरी समझ यह है कि एक वर्ग उदाहरण जिसे मैं गतिशील रूप से instansiate बनाया जाएगा पूरी तरह से ढेर (सभी सदस्य चर सहित) पर आवंटित किया जाएगा जब यह बनाया गया है। मैं यहां जो अंतर देखता हूं वह यह होगा कि संदेश की घोषणाओं को रन फ़ंक्शन में ले जाने के बजाय उन्हें स्टैक पर रखा जाता है। इस मामले में ढेर कक्षा के पूरे आकार को बढ़ाने के लिए काफी बड़ा है। ऐसा लगता है कि विशिष्ट हिस्सों का उपयोग तब तक पर्याप्त स्मृति आवंटित नहीं किया जा रहा है?
संदेश कक्षाएं स्वयं के गतिशील आवंटन नहीं करती हैं। (और यदि उन्होंने किया, तो मैं घोषणा करता हूं कि घोषणा इस मामले में व्यवहार को नहीं बदलेगी और मुझे अभी भी ढेर के आकार में बदलाव दिखाई देगा।)
स्मृति आवंटन की निगरानी करने के लिए मैं निम्नलिखित का उपयोग कर रहा हूं VxWorks memLib (या memPartLib) कॉल:
memPartInfoGet(memSysPartId, &partitionStatus);
...
bytesFree = partitionStatus.numBytesFree;
संपादित करें:
स्पष्ट करने के लिए, MyClass वस्तु instansiated जाता है और एक प्रारंभ दिनचर्या में प्रारंभ और उसके बाद कोड में प्रवेश करती है दर-सुरक्षित प्रसंस्करण। इस समय के दौरान, एक धारावाहिक रेखा (कमांड या स्थिति संदेश ऑब्जेक्ट्स के साथ पहली बातचीत) पर कमांड संदेश प्राप्त होने पर अतिरिक्त मेमोरी आवंटित की जाती है (या बाइट्स की संख्या कम हो जाती है)। यह बुरा है क्योंकि गतिशील स्मृति आवंटन निर्धारक नहीं है।
मैं कर लिया है के रूप में मैं का वर्णन किया है वर्ग चर ले जाकर समस्या से छुटकारा पाने के।
यह स्पष्ट रूप से स्पष्ट नहीं है कि आपकी समस्या क्या है, क्या आप सामान सदस्यों को स्टैक पर बनाम सामान के रूप में आवंटित करने वाली अधिक मेमोरी का उपयोग करते हैं, या यह है कि उपयोग की गई स्मृति किसी एक मामले में समय के साथ बदलती है? – nos
क्या आप सार्वजनिक अनुभाग में सदस्यों को उठाते समय आकार (MyClass) बदलते हैं? और स्मृति आवंटन कितना बदलता है? –
* आवंटन कब बदलता है? छोटे वर्ग वस्तुओं के ढेर पर एक मुक्त ब्लॉक में एक आसान समय फिटिंग है। –