C ++ में स्टोरेज क्लासेस

एक भंडारण वर्ग एक सी ++ प्रोग्राम के दायरे (/ दृश्यता) और चर के जीवनकाल और / या कार्यों को परिभाषित करता है। ये विनिर्देशक उस प्रकार को पसंद करते हैं जिसे वे संशोधित करते हैं। निम्नलिखित भंडारण वर्ग हैं, जिनका उपयोग C ++ प्रोग्राम में किया जा सकता है

  • auto
  • register
  • static
  • extern
  • mutable

ऑटो स्टोरेज क्लास

auto भंडारण कक्षा सभी स्थानीय चर के लिए डिफ़ॉल्ट भंडारण वर्ग है।

{
   int mount;
   auto int month;
}

उपरोक्त उदाहरण एक ही भंडारण वर्ग के साथ दो चर को परिभाषित करता है, ऑटो का उपयोग केवल फ़ंक्शंस अर्थात स्थानीय चर में किया जा सकता है।

रजिस्टर भंडारण वर्ग

registerभंडारण वर्ग का उपयोग स्थानीय चर को परिभाषित करने के लिए किया जाता है जिन्हें रैम के बजाय एक रजिस्टर में संग्रहीत किया जाना चाहिए। इसका मतलब यह है कि चर का आकार रजिस्टर आकार (आमतौर पर एक शब्द) के बराबर होता है और उस पर लागू 'और' ऑपरेटर नहीं होता है (क्योंकि इसमें मेमोरी लोकेशन नहीं होता है)।

{
   register int  miles;
}

रजिस्टर का उपयोग केवल उन चर के लिए किया जाना चाहिए जिनके लिए काउंटर जैसे त्वरित पहुंच की आवश्यकता होती है। यह भी ध्यान दिया जाना चाहिए कि 'रजिस्टर' को परिभाषित करने का मतलब यह नहीं है कि चर को एक रजिस्टर में संग्रहीत किया जाएगा। इसका अर्थ है कि हार्डवेयर और कार्यान्वयन प्रतिबंधों के आधार पर इसे एक रजिस्टर में संग्रहीत किया जाना चाहिए।

स्थिर भंडारण वर्ग

staticभंडारण वर्ग कंपाइलर को निर्देश देता है कि वह प्रोग्राम के जीवन-समय के दौरान उसे बनाने और उसे नष्ट करने के बजाय जीवन के समय के दौरान एक स्थानीय चर को अस्तित्व में रखे। इसलिए, स्थानीय चर को स्थिर बनाने से उन्हें फ़ंक्शन कॉल के बीच अपने मूल्यों को बनाए रखने की अनुमति मिलती है।

स्थैतिक संशोधक को वैश्विक चर पर भी लागू किया जा सकता है। जब यह किया जाता है, तो यह उस चर के दायरे को उस फ़ाइल तक सीमित रखने का कारण बनता है जिसमें इसे घोषित किया गया है।

C ++ में, जब स्थैतिक का उपयोग किसी वर्ग डेटा सदस्य पर किया जाता है, तो यह उस सदस्य की केवल एक प्रति को उसके वर्ग के सभी ऑब्जेक्ट द्वारा साझा करने का कारण बनता है।

#include <iostream>
 
// Function declaration
void func(void);
 
static int count = 10; /* Global variable */
 
main() {
   while(count--) {
      func();
   }
   
   return 0;
}

// Function definition
void func( void ) {
   static int i = 5; // local static variable
   i++;
   std::cout << "i is " << i ;
   std::cout << " and count is " << count << std::endl;
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

i is 6 and count is 9
i is 7 and count is 8
i is 8 and count is 7
i is 9 and count is 6
i is 10 and count is 5
i is 11 and count is 4
i is 12 and count is 3
i is 13 and count is 2
i is 14 and count is 1
i is 15 and count is 0

एक्सटर्नल स्टोरेज क्लास

externभंडारण वर्ग का उपयोग एक वैश्विक चर का संदर्भ देने के लिए किया जाता है जो सभी प्रोग्राम फ़ाइलों के लिए दिखाई देता है। जब आप 'एक्सटर्नल' का उपयोग करते हैं तो वैरिएबल को इनिशियलाइज़ नहीं किया जा सकता है क्योंकि यह सभी स्टोरेज लोकेशन पर वैरिएबल नाम को इंगित करता है जिसे पहले परिभाषित किया गया है।

जब आपके पास कई फाइलें होती हैं और आप एक वैश्विक चर या फ़ंक्शन को परिभाषित करते हैं, जिसका उपयोग अन्य फ़ाइलों में भी किया जाएगा , तो बाहरी चर का उपयोग परिभाषित चर या फ़ंक्शन के संदर्भ देने के लिए किसी अन्य फ़ाइल में किया जाएगा। बस बाहरी समझ के लिए एक वैश्विक चर या फ़ंक्शन को किसी अन्य फ़ाइल में घोषित करने के लिए उपयोग किया जाता है।

बाहरी मॉडिफ़ायर का सबसे अधिक उपयोग तब किया जाता है, जब एक ही वैश्विक चर या फ़ंक्शंस को साझा करने वाली दो या अधिक फाइलें होती हैं, जैसा कि नीचे बताया गया है।

पहली फ़ाइल: main.cpp

#include <iostream>
int count ;
extern void write_extern();
 
main() {
   count = 5;
   write_extern();
}

दूसरी फ़ाइल: support.cpp

#include <iostream>

extern int count;

void write_extern(void) {
   std::cout << "Count is " << count << std::endl;
}

यहां, एक अन्य फ़ाइल में गिनती घोषित करने के लिए बाहरी कीवर्ड का उपयोग किया जा रहा है। अब इन दो फाइलों को इस प्रकार संकलित करें -

$g++ main.cpp support.cpp -o write

इससे उत्पादन होगा write निष्पादन योग्य कार्यक्रम, निष्पादित करने का प्रयास करें write और परिणाम की जाँच इस प्रकार है -

$./write
5

म्यूटेबल स्टोरेज क्लास

mutableविनिर्देश केवल क्लास ऑब्जेक्ट्स पर लागू होता है, जिन्हें बाद में इस ट्यूटोरियल में चर्चा की गई है। यह किसी सदस्य को कॉन्स्टेबल सदस्य फ़ंक्शन को ओवरराइड करने की अनुमति देता है। अर्थात्, एक उत्परिवर्तित सदस्य को एक कास्ट सदस्य फ़ंक्शन द्वारा संशोधित किया जा सकता है।