एक्सटर्नल वेरिएबल: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
 
(21 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{Short description|Variable defined outside any function block in C programming}}
{{Short description|Variable defined outside any function block in C programming}}सी प्रोग्रामिंग भाषा में, '''एक्सटर्नल वेरिएबल''' किसी भी फ़ंक्शन ब्लॉक के बाहर परिभाषित वेरिएबल है। दूसरी ओर, स्थानीय (स्वचालित) वेरिएबल फ़ंक्शन ब्लॉक के अंदर परिभाषित वेरिएबल है।
{{redirect|
बाहरी|नौकरी का शीर्षक|एक्सटर्नशिप}}


[[सी प्रोग्रामिंग भाषा]] में, बाहरी चर किसी भी फ़ंक्शन ब्लॉक के बाहर परिभाषित चर है। दूसरी ओर, स्थानीय (स्वचालित) चर फ़ंक्शन ब्लॉक के अंदर परिभाषित चर है।
{{quote|स्वचालित चर के विकल्प के रूप में, उन चरों को परिभाषित करना संभव है जो सभी कार्यों के लिए बाहरी हैं, अर्थात वे चर जिन्हें किसी भी कार्य द्वारा नाम से पहुँचाया जा सकता है। (यह प्रणाली [[फोरट्रान]] सामान्य या [[पास्कल (प्रोग्रामिंग लैंग्वेज) | पास्कल]] चर के जैसे है जो सबसे बाहरी ब्लॉक में घोषित किया गया है।) क्योंकि बाहरी चर विश्व स्तर पर सुलभ हैं, डेटा को संप्रेषित करने के लिए तर्क सूचियों के अतिरिक्त उनका उपयोग किया जा सकता है। कार्यों के मध्य इसके अतिरिक्त, क्योंकि बाह्य चर स्थायी रूप से अस्तित्व में रहते हैं, अतिरिक्त प्रकट होने और विलुप्त होने के अतिरिक्त कार्यों को कहा जाता है और बाहर निकल जाते हैं, वे अपने मूल्यों को बनाए रखते हैं, उन्हें निर्धारित करने वाले कार्य वापस आ गए हों।|''[[The C Programming Language]]''}}
 
{{quote|As an alternative to automatic variables, it is possible to define variables that are external to all functions, that is, variables that can be accessed by name by any function. (This mechanism is rather like [[Fortran]] COMMON or [[Pascal (programming language)|Pascal]] variables declared in the outermost block.) Because external variables are globally accessible, they can be used instead of argument lists to communicate data between functions. Furthermore, because external variables remain in existence permanently, rather than appearing and disappearing as functions are called and exited, they retain their values even after the functions that set them have returned.|''[[The C Programming Language]]''}}


== परिभाषा, घोषणा और <code>extern</code> कीवर्ड ==
== परिभाषा, घोषणा और <code>extern</code> कीवर्ड ==
यह समझने के लिए कि बाह्य चर <code>extern</code> कीवर्ड किस प्रकार संबंधित हैं, चर को परिभाषित करने और घोषित करने के मध्य के अंतर को जानना आवश्यक है। जब चर को परिभाषित किया जाता है, तो संकलक उस चर के लिए स्मृति आवंटित करता है और संभवतया इसकी सामग्री को कुछ मान में प्रारंभ करता है। जब चर घोषित किया जाता है, तो संकलक को चर को कहीं और परिभाषित करने की आवश्यकता होती है। घोषणापत्र संकलक को सूचित करता है कि उस नाम और प्रकार से चर उपस्थित है, किन्तु संकलक को इसके लिए स्मृति आवंटित करने की आवश्यकता नहीं है क्योंकि इसे कहीं और आवंटित किया गया है। <code>extern</code>  कीवर्ड का अर्थ है बिना परिभाषित किए घोषित करना, दूसरे शब्दों में, यह चर को स्पष्ट रूप से घोषित करने की प्रविधि है, या परिभाषा के बिना घोषणा को बाध्य करने की प्रविधि है। चर को स्पष्ट रूप से परिभाषित करना भी संभव है, अर्थात परिभाषा को बाध्य करना है। यह  चर को प्रारंभिक मूल्य असाइन करके किया जाता है। यदि न तो <code>extern</code> कीवर्ड और न ही प्रारंभिक मूल्य उपस्थित हैं, कथन या तो घोषणा या परिभाषा हो सकती है। यह कंपाइलर पर निर्भर करता है कि वह प्रोग्राम के मॉड्यूल्स का विश्लेषण और निर्धारित करे।
यह विचार करने के लिए कि बाह्य वेरिएबल <code>extern</code> कीवर्ड किस प्रकार संबंधित हैं, वेरिएबल को परिभाषित करने और घोषित करने के मध्य के अंतर को जानना आवश्यक है। जब वेरिएबल को परिभाषित किया जाता है, तो संकलक उस वेरिएबल के लिए मैमोरी आवंटित करता है और संभवतया इसकी सामग्री को कुछ मान में प्रारंभ करता है। जब वेरिएबल घोषित किया जाता है, तो संकलक को वेरिएबल को कहीं और परिभाषित करने की आवश्यकता होती है। घोषणापत्र संकलक को सूचित करता है कि उस नाम और प्रकार से वेरिएबल उपस्थित है, किन्तु संकलक को इसके लिए मैमोरी आवंटित करने की आवश्यकता नहीं है क्योंकि इसे कहीं और आवंटित किया गया है। <code>extern</code>  कीवर्ड का अर्थ है बिना परिभाषित किए घोषित करना, दूसरे शब्दों में, यह वेरिएबल को स्पष्ट रूप से घोषित करने की प्रविधि है, या परिभाषा के बिना घोषणा को बाध्य करने की प्रविधि है। वेरिएबल को स्पष्ट रूप से परिभाषित करना भी संभव है, अर्थात परिभाषा को बाध्य करना है। यह  वेरिएबल को प्रारंभिक मूल्य असाइन करके किया जाता है। यदि न तो <code>extern</code> कीवर्ड और न ही प्रारंभिक मूल्य उपस्थित हैं, कथन या तो घोषणा या परिभाषा हो सकती है। यह कंपाइलर पर निर्भर करता है कि वह प्रोग्राम के मॉड्यूल्स का विश्लेषण करे और निर्धारित करे।


कार्यक्रम के मॉड्यूल में चर को परिभाषित किया जाना चाहिए। यदि कोई परिभाषा एक से अधिक नहीं है, तो संभवतः लिंकिंग चरण में त्रुटि उत्पन्न होती है। चर को कई बार घोषित किया जा सकता है, जब तक कि घोषणाएं दूसरे के साथ और परिभाषा के अनुरूप हों (कुछ ऐसा है जो [[शीर्षलेख फ़ाइलें]] अधिक सुविधा प्रदान करती है)। इसे कई मॉड्यूल में घोषित किया जा सकता है, जिसमें वह मॉड्यूल भी सम्मिलित है जहां इसे परिभाषित किया गया था, और यहां तक ​​कि मॉड्यूल में कई बार, किन्तु सामान्यतः मॉड्यूल में इसे अधिक बार घोषित करना व्यर्थ होता है।
कार्यक्रम के मॉड्यूल में वेरिएबल को परिभाषित किया जाना चाहिए। यदि कोई परिभाषा एक से अधिक नहीं है, तो संभवतः लिंकिंग वेरिएबलण में त्रुटि उत्पन्न होती है। वेरिएबल को कई बार घोषित किया जा सकता है, जब तक कि घोषणाएं दूसरे के साथ और परिभाषा के अनुरूप हों (कुछ ऐसा है जो शीर्षलेख फ़ाइलें अधिक सुविधा प्रदान करती है)। इसे कई मॉड्यूल में घोषित किया जा सकता है, जिसमें वह मॉड्यूल भी सम्मिलित है जहां इसे परिभाषित किया गया था, और यहां तक ​​कि मॉड्यूल में कई बार, किन्तु सामान्यतः मॉड्यूल में इसे अधिक बार घोषित करना व्यर्थ होता है।


किसी फ़ंक्शन के अंदर बाहरी चर भी घोषित किया जा सकता है। इस स्थिति में <code>extern</code> कीवर्ड का उपयोग किया जाना चाहिए, अन्यथा संकलक इसे स्थानीय चर की परिभाषा मानेगा, जिसकी भिन्न सीमा, जीवनकाल और प्रारंभिक मूल्य है। यह घोषणा सम्पूर्ण फंक्शन के मॉड्यूल के अतिरिक्त केवल फंक्शन के अंदर ही दिखाई देगी। <code>extern</code> किसी फ़ंक्शन प्रोटोटाइप पर लागू किया गया कीवर्ड बिल्कुल कुछ नहीं करता है ( <code>extern</code> कीवर्ड फ़ंक्शन परिभाषा पर लागू होता है, ज़ाहिर है, गैर-सनसनीखेज)। एक फ़ंक्शन प्रोटोटाइप हमेशा एक घोषणा है और परिभाषा कभी नहीं। साथ ही, मानक सी में, एक फ़ंक्शन हमेशा बाहरी होता है, किन्तु कुछ कंपाइलर एक्सटेंशन फ़ंक्शन को फ़ंक्शन के अंदर परिभाषित करने की अनुमति देते हैं।
किसी फ़ंक्शन के अंदर एक्सटर्नल वेरिएबल भी घोषित किया जा सकता है। इस स्थिति में <code>extern</code> कीवर्ड का उपयोग किया जाना चाहिए, अन्यथा संकलक इसे स्थानीय वेरिएबल की परिभाषा मानेगा, जिसकी भिन्न सीमा, जीवनकाल और प्रारंभिक मूल्य है। यह घोषणा सम्पूर्ण फंक्शन के मॉड्यूल के अतिरिक्त केवल फंक्शन के अंदर ही दिखाई देगी। फ़ंक्शन प्रोटोटाइप पर प्रारम्भ <code>extern</code> कीवर्ड बिल्कुल कुछ नहीं करता है ( फ़ंक्शन परिभाषा पर प्रारम्भ <code>extern</code> कीवर्ड निश्चित रूप से गैर-भयावह है)। फ़ंक्शन प्रोटोटाइप सदैव घोषणा है और परिभाषा कभी नहीं है। साथ ही, मानक सी में, फ़ंक्शन सदैव एक्सटर्नल होता है, किन्तु कुछ कंपाइलर एक्सटेंशन फ़ंक्शन को फ़ंक्शन के अंदर परिभाषित करने की अनुमति देते हैं।


{{quote|
{{quote|
An external variable must be defined, exactly once, outside of any function; this sets aside storage for it. The variable must also be declared in each function that wants to access it; this states the type of the variable. The declaration may be an explicit <code>extern</code> statement or may be implicit from context.
बाहरी चर को परिभाषित किया जाना चाहिए, किसी भी फ़ंक्शन के बाहर; यह इसके लिए भंडारण को भिन्न करता है। चर को प्रत्येक फ़ंक्शन में भी घोषित किया जाना चाहिए जो इसे एक्सेस करना चाहता है; यह चर के प्रकार को बताता है। घोषणा  स्पष्ट हो सकती है।<code>extern</code> कथन या संदर्भ से निहित हो सकता है।
...
...
You should note that we are using the words definition and declaration carefully when we refer to external variables in this section. ''Definition'' refers to the place where the variable is created or assigned storage; ''declaration'' refers to places where the nature of the variable is stated but no storage is allocated.
आपको ध्यान देना चाहिए कि जब इस खंड में बाहरी चरों का उल्लेख करते हैं तो हम परिभाषा और घोषणा शब्दों का सावधानीपूर्वक उपयोग कर रहे हैं। ''परिभाषा'' उस स्थान को संदर्भित करता है जहां चर बनाया जाता है या भंडारण प्रदान किया जाता है; ''घोषणा'' उन स्थानों को संदर्भित करता है जहां चर की प्रकृति बताई गई है किन्तु कोई भंडारण आवंटित नहीं किया गया है।|''[[The C Programming Language]]''}}
|''[[The C Programming Language]]''}}
 
== क्षेत्र, जीवनकाल और <code>static</code> कीवर्ड ==
{{See also|स्थिर (कीवर्ड)}}


== दायरा, जीवनकाल और <code>static</code> कीवर्ड ==
प्रोग्राम के सभी मॉड्यूल में सभी कार्यों द्वारा एक्सटर्नल वेरिएबल का उपयोग किया जा सकता है। यह [[वैश्विक चर|वैश्विक वेरिएबल]] है। फ़ंक्शन के लिए वेरिएबल का उपयोग करने में सक्षम होने के लिए, स्रोत कोड में फ़ंक्शन परिभाषा से पूर्व घोषणा या एक्सटर्नल वेरिएबल की परिभाषा होनी चाहिए। या कीवर्ड के साथ <code>extern</code>, फंक्शन के अंदर वेरिएबल की घोषणा होनी चाहिए।
{{See also|Static (keyword)}}
एक प्रोग्राम के सभी मॉड्यूल में सभी कार्यों द्वारा एक बाहरी चर का उपयोग किया जा सकता है। यह एक [[वैश्विक चर]] है। एक फ़ंक्शन के लिए चर का उपयोग करने में सक्षम होने के लिए, स्रोत कोड में फ़ंक्शन परिभाषा से पहले एक घोषणा या बाहरी चर की परिभाषा होनी चाहिए। या कीवर्ड के साथ चर की घोषणा होनी चाहिए <code>extern</code>, समारोह के अंदर।


द स्टेटिक (कीवर्ड) |<code>static</code> खोजशब्द (<code>static</code> और <code>extern</code> पारस्परिक रूप से अनन्य हैं), बाहरी चर की परिभाषा पर लागू होता है, इसे थोड़ा बदल देता है: चर को केवल उसी मॉड्यूल में फ़ंक्शंस द्वारा एक्सेस किया जा सकता है जहां इसे परिभाषित किया गया था। किन्तु एक ही मॉड्यूल में एक फ़ंक्शन के लिए चर के संदर्भ (सूचक) को दूसरे मॉड्यूल में किसी अन्य फ़ंक्शन में पास करना संभव है। इस मामले में, भले ही फ़ंक्शन किसी अन्य मॉड्यूल में है, यह चर की सामग्री को पढ़ और संशोधित कर सकता है-यह सिर्फ नाम से इसका उल्लेख नहीं कर सकता।
स्थैतिक कीवर्ड <code>static</code> (<code>static</code> और <code>extern</code> पारस्परिक रूप से अनन्य हैं), एक्सटर्नल वेरिएबल की परिभाषा पर प्रारम्भ होता है, इसे थोड़ा परिवर्तित कर देता है। वेरिएबल को केवल उसी मॉड्यूल में फ़ंक्शंस द्वारा एक्सेस किया जा सकता है जहां इसे परिभाषित किया गया था। किन्तु मॉड्यूल में फ़ंक्शन के लिए वेरिएबल के संदर्भ (पॉइंटर) को दूसरे मॉड्यूल में किसी अन्य फ़ंक्शन में निकट करना संभव है। इस स्थिति में, फ़ंक्शन किसी अन्य मॉड्यूल में है, यह वेरिएबल की सामग्री को पढ़ और संशोधित कर सकता है, यह सिर्फ नाम से इसका उल्लेख नहीं कर सकता हैं।


का प्रयोग करना भी संभव है <code>static</code> स्थानीय चर की परिभाषा पर कीवर्ड। के बिना <code>static</code> कीवर्ड, फ़ंक्शन को कॉल किए जाने पर चर स्वचालित रूप से आवंटित किया जाता है और फ़ंक्शन से बाहर निकलने पर जारी किया जाता है (इस प्रकार नाम स्वचालित चर)। फ़ंक्शन कॉल के मध्य इसका मान नहीं रखा जाता है। साथ <code>static</code> कीवर्ड, कार्यक्रम शुरू होने पर चर आवंटित किया जाता है और कार्यक्रम समाप्त होने पर जारी किया जाता है। फ़ंक्शन कॉल के मध्य इसका मान खो नहीं जाता है। चर अभी भी स्थानीय है, क्योंकि इसे केवल उस फ़ंक्शन के अंदर नाम से ही एक्सेस किया जा सकता है जिसने इसे परिभाषित किया है। किन्तु इसके लिए एक संदर्भ (सूचक) किसी अन्य फ़ंक्शन को पास किया जा सकता है, जिससे इसे चर की सामग्री को पढ़ने और संशोधित करने की अनुमति मिलती है (फिर से नाम से संदर्भित किए बिना)।
स्थानीय वेरिएबल की परिभाषा पर शोध शब्द का प्रयोग करना भी संभव है।  <code>static</code> कीवर्ड के बिना फ़ंक्शन को कॉल किए जाने पर वेरिएबल स्वचालित रूप से आवंटित किया जाता है और फ़ंक्शन से बाहर निकलने पर प्रचलित किया जाता है (इस प्रकार नाम स्वचालित वेरिएबल)। फ़ंक्शन कॉल के मध्य इसका मान नहीं रखा जाता है। <code>static</code> कीवर्ड के साथ, कार्यक्रम प्रारम्भ होने पर वेरिएबल आवंटित किया जाता है और कार्यक्रम समाप्त होने पर प्रचलित किया जाता है। फ़ंक्शन कॉल के मध्य इसका मान लुप्त नहीं हो जाता है। वेरिएबल अभी भी स्थानीय है, क्योंकि इसे केवल उस फ़ंक्शन के अंदर नाम से ही एक्सेस किया जा सकता है जिसने इसे परिभाषित किया है। किन्तु इसके लिए संदर्भ (पॉइंटर) किसी अन्य फ़ंक्शन को निकट किया जा सकता है, जिससे इसे वेरिएबल की सामग्री को पढ़ने और संशोधित करने की अनुमति मिलती है (नाम से संदर्भित किए बिना)।


प्रोग्राम शुरू होने पर बाहरी चर आवंटित और आरंभ किए जाते हैं, और प्रोग्राम समाप्त होने पर ही मेमोरी जारी की जाती है। उनका जीवनकाल कार्यक्रम के समान ही है।
प्रोग्राम प्रारम्भ होने पर एक्सटर्नल वेरिएबल आवंटित और आरंभ किए जाते हैं, और प्रोग्राम समाप्त होने पर ही मेमोरी प्रचलित की जाती है। उनका जीवनकाल कार्यक्रम के समान ही है।


यदि इनिशियलाइज़ेशन स्पष्ट रूप से नहीं किया गया है, तो बाहरी (स्थिर या नहीं) और स्थानीय स्थिर चर को शून्य से आरंभ किया जाता है। स्थानीय स्वचालित चर अप्रारंभीकृत हैं, अर्थात ट्रैश मान सम्मिलित हैं। <code>static</code> फ़ंक्शन परिभाषा पर लागू किया गया e> कीवर्ड फ़ंक्शन के लिंकेज को बदल देता है ताकि यह केवल अनुवाद इकाई से दिखाई दे जहां इसकी परिभाषा स्थित है। यह फ़ंक्शन को इसके मॉड्यूल के बाहर से नाम से बुलाए जाने से रोकता है (मॉड्यूल से [[समारोह सूचक]] को पास करना संभव है और फ़ंक्शन का आह्वान करने के लिए इसका उपयोग करना संभव है)। का उपयोग कर एक समारोह घोषित करना <code>static</code> नाम के टकराव से बचते हुए अपने नाम को छोटा रखने के लिए कीवर्ड भी एक अच्छा तरीका है।
यदि प्रारम्भिकरण स्पष्ट रूप से नहीं किया गया है, तो एक्सटर्नल (स्थिर या नहीं) और स्थानीय स्थिर वेरिएबल को शून्य से आरंभ किया जाता है। स्थानीय स्वचालित वेरिएबल अप्रारंभीकृत हैं, अर्थात ट्रैश मान सम्मिलित हैं। फ़ंक्शन परिभाषा पर प्रारम्भ किया गया <code>static</code> कीवर्ड फ़ंक्शन के लिंकेज को परिवर्तित कर देता है, जिससे यह केवल अनुवाद इकाई से दिखाई दे जहां इसकी परिभाषा स्थित है। यह फ़ंक्शन को इसके मॉड्यूल के बाहर से नाम से बुलाए जाने से रोकता है (मॉड्यूल से फंक्शन पॉइंटर को निकट करना संभव है और फ़ंक्शन का आह्वान करने के लिए इसका उपयोग करना संभव है)। <code>static</code> कीवर्ड का उपयोग करके किसी फ़ंक्शन को घोषित करना भी नाम के अवरोध से बचने के लिए उसका नाम अल्प रखने की उत्तम प्रविधि है।


== उदाहरण (सी प्रोग्रामिंग भाषा) ==
== उदाहरण (सी प्रोग्रामिंग भाषा) ==
Line 62: Line 58:
   }
   }
</syntaxhighlight>
</syntaxhighlight>
इस उदाहरण में, चर Global_Variable को फ़ाइल 1 में परिभाषित किया गया है। फ़ाइल 2 में समान चर का उपयोग करने के लिए, इसे घोषित किया जाना चाहिए। फ़ाइलों की संख्या के बावजूद, एक वैश्विक चर को केवल एक बार परिभाषित किया जाता है; हालाँकि, इसे परिभाषा वाली फ़ाइल के बाहर किसी भी फ़ाइल में घोषित किया जाना चाहिए।
इस उदाहरण में, वेरिएबल Global_Variable को फ़ाइल 1 में परिभाषित किया गया है। फ़ाइल 2 में समान वेरिएबल का उपयोग करने के लिए, इसे घोषित किया जाना चाहिए। फ़ाइलों की संख्या के पश्चात भी, वैश्विक वेरिएबल को परिभाषित किया जाता है; चूंकि, इसे परिभाषा वाली फ़ाइल के बाहर किसी भी फ़ाइल में घोषित किया जाना चाहिए।


{{quote|
{{quote|
If the program is in several source files, and a variable is defined in file1 and used in file2 and file3, then extern declarations are needed in file2 and file3 to connect the occurrences of the variable. The usual practice is to collect extern declarations of variables and functions in a separate file, historically called a header, that is included by #include at the front of each source file. The suffix .h is conventional for header names.
यदि प्रोग्राम कई स्रोत फ़ाइलों में है, और चर को फ़ाइल 1 में परिभाषित किया गया है और फ़ाइल 2 और फ़ाइल 3 में उपयोग किया जाता है, तो चर की घटनाओं को जोड़ने के लिए फ़ाइल 2 और फ़ाइल 3 में बाहरी घोषणाओं की आवश्यकता होती है। सामान्य अभ्यास भिन्न फ़ाइल में चर और कार्यों की बाहरी घोषणाओं को एकत्र करना है, जिसे ऐतिहासिक रूप से हेडर कहा जाता है, जिसे प्रत्येक स्रोत फ़ाइल के सामने सम्मिलित किया जाता है। हेडर नामों के लिए प्रत्यय पारंपरिक है।
|''[[The C Programming Language]]''}}
|''[[The C Programming Language]]''}}


सी फाइलों में जाने के लिए सामान्य पद्धति आवंटन और वास्तविक परिभाषाओं के लिए है, किन्तु केवल घोषणाएं और प्रोटोटाइप आवंटित नहीं होते हैं और केवल प्रकार और पैरामीटर का वर्णन करते हैं ताकि संकलक सही ढंग से काम कर सके, और वह जानकारी एक एच हेडर फ़ाइल में है जो अन्य बिना किसी संभावित संघर्ष के सुरक्षित रूप से सम्मिलित कर सकते हैं।
सी फाइलों में जाने के लिए सामान्य पद्धति आवंटन और वास्तविक परिभाषाओं के लिए है, किन्तु केवल घोषणाएं और प्रोटोटाइप आवंटित नहीं होते हैं और केवल प्रकार और पैरामीटर का वर्णन करते हैं जिससे संकलक उचित रूप से कार्य कर सके, और वह जानकारी एच हेडर फ़ाइल में है जो अन्य बिना किसी संभावित संघर्ष के सुरक्षित रूप से सम्मिलित कर सकते हैं।


== यह भी देखें ==
== यह भी देखें ==
* {{annotated link|Declaration (computer programming) |Declaration}}
* {{annotated link|Declaration (computer programming) |घोषणा}}
* {{annotated link|Function prototype}}
* {{annotated link|फंक्शन प्रोटोटाइप}}
* {{annotated link|Global variable}}
* {{annotated link|वैश्विक चर}}
* {{annotated link|Linker (computing)}}
* {{annotated link|लिंकर (कंप्यूटिंग)}}
* {{annotated link|Local variable}}
* {{annotated link|स्थानीय चर}}
* {{annotated link|Scope (computer science)|Scope}}
* {{annotated link|Scope (computer science)|क्षेत्र}}
* {{annotated link|Static variable}}
* {{annotated link|स्थैतिक चर}}
* {{annotated link|The C Programming Language|''The C Programming Language''}}
* {{annotated link|सी प्रोग्रामिंग लैंग्वेज|सी प्रोग्रामिंग लैंग्वेज}}


== बाहरी संबंध ==
== एक्सटर्नल संबंध ==
* [https://docs.microsoft.com/en-us/cpp/c-language/storage-class-specifiers-for-external-level-declarations Microsoft C Language Reference: Storage-Class Specifiers for External-Level Declarations]
* [https://docs.microsoft.com/en-us/cpp/c-language/storage-class-specifiers-for-external-level-declarations Microsoft C Language Reference: Storage-Class Specifiers for External-Level Declarations]
* {{cite web|url= http://www.open-std.org/JTC1/SC22/WG14/www/docs/n1256.pdf |title=The C Standard (C99 with Technical corrigenda TC1, TC2, and TC3 included) }}&nbsp;{{small|(3.61&nbsp;[[Mebibyte|MiB]])}}. In particular, see sections 6.2.2 (Linkage of identifiers), 6.2.4 (Storage duration of objects), 6.7.1 (Storage-class specifiers) and 6.9 (External definitions).
* {{cite web|url= http://www.open-std.org/JTC1/SC22/WG14/www/docs/n1256.pdf |title=The C Standard (C99 with Technical corrigenda TC1, TC2, and TC3 included) }}&nbsp;{{small|(3.61&nbsp;[[Mebibyte|MiB]])}}. In particular, see sections 6.2.2 (Linkage of identifiers), 6.2.4 (Storage duration of objects), 6.7.1 (Storage-class specifiers) and 6.9 (External definitions).
[[Category: चर (कंप्यूटर विज्ञान)]]


[[Category: Machine Translated Page]]
[[Category:Articles with hatnote templates targeting a nonexistent page]]
[[Category:Created On 15/05/2023]]
[[Category:Created On 15/05/2023]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Missing redirects]]
[[Category:Pages with script errors]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]
[[Category:चर (कंप्यूटर विज्ञान)]]

Latest revision as of 16:32, 30 October 2023

सी प्रोग्रामिंग भाषा में, एक्सटर्नल वेरिएबल किसी भी फ़ंक्शन ब्लॉक के बाहर परिभाषित वेरिएबल है। दूसरी ओर, स्थानीय (स्वचालित) वेरिएबल फ़ंक्शन ब्लॉक के अंदर परिभाषित वेरिएबल है।

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

परिभाषा, घोषणा और extern कीवर्ड

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

कार्यक्रम के मॉड्यूल में वेरिएबल को परिभाषित किया जाना चाहिए। यदि कोई परिभाषा एक से अधिक नहीं है, तो संभवतः लिंकिंग वेरिएबलण में त्रुटि उत्पन्न होती है। वेरिएबल को कई बार घोषित किया जा सकता है, जब तक कि घोषणाएं दूसरे के साथ और परिभाषा के अनुरूप हों (कुछ ऐसा है जो शीर्षलेख फ़ाइलें अधिक सुविधा प्रदान करती है)। इसे कई मॉड्यूल में घोषित किया जा सकता है, जिसमें वह मॉड्यूल भी सम्मिलित है जहां इसे परिभाषित किया गया था, और यहां तक ​​कि मॉड्यूल में कई बार, किन्तु सामान्यतः मॉड्यूल में इसे अधिक बार घोषित करना व्यर्थ होता है।

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

बाहरी चर को परिभाषित किया जाना चाहिए, किसी भी फ़ंक्शन के बाहर; यह इसके लिए भंडारण को भिन्न करता है। चर को प्रत्येक फ़ंक्शन में भी घोषित किया जाना चाहिए जो इसे एक्सेस करना चाहता है; यह चर के प्रकार को बताता है। घोषणा स्पष्ट हो सकती है।extern कथन या संदर्भ से निहित हो सकता है। ...

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

क्षेत्र, जीवनकाल और static कीवर्ड

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

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

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

प्रोग्राम प्रारम्भ होने पर एक्सटर्नल वेरिएबल आवंटित और आरंभ किए जाते हैं, और प्रोग्राम समाप्त होने पर ही मेमोरी प्रचलित की जाती है। उनका जीवनकाल कार्यक्रम के समान ही है।

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

उदाहरण (सी प्रोग्रामिंग भाषा)

फ़ाइल 1:

  // Explicit definition, this actually allocates
  // as well as describing
  int global_variable;

  // Function prototype (declaration), assumes 
  // defined elsewhere, normally from include file.       
  void some_function(void);        

  int main(void) {
    global_variable = 1;
    some_function();
    return 0;
  }

फ़ाइल 2:

  // Implicit declaration, this only describes and
  // assumes allocated elsewhere, normally from include
  extern int global_variable;  

  // Function header (definition)
  void some_function(void) {       
    ++global_variable;
  }

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

यदि प्रोग्राम कई स्रोत फ़ाइलों में है, और चर को फ़ाइल 1 में परिभाषित किया गया है और फ़ाइल 2 और फ़ाइल 3 में उपयोग किया जाता है, तो चर की घटनाओं को जोड़ने के लिए फ़ाइल 2 और फ़ाइल 3 में बाहरी घोषणाओं की आवश्यकता होती है। सामान्य अभ्यास भिन्न फ़ाइल में चर और कार्यों की बाहरी घोषणाओं को एकत्र करना है, जिसे ऐतिहासिक रूप से हेडर कहा जाता है, जिसे प्रत्येक स्रोत फ़ाइल के सामने सम्मिलित किया जाता है। हेडर नामों के लिए प्रत्यय पारंपरिक है।

सी फाइलों में जाने के लिए सामान्य पद्धति आवंटन और वास्तविक परिभाषाओं के लिए है, किन्तु केवल घोषणाएं और प्रोटोटाइप आवंटित नहीं होते हैं और केवल प्रकार और पैरामीटर का वर्णन करते हैं जिससे संकलक उचित रूप से कार्य कर सके, और वह जानकारी एच हेडर फ़ाइल में है जो अन्य बिना किसी संभावित संघर्ष के सुरक्षित रूप से सम्मिलित कर सकते हैं।

यह भी देखें

एक्सटर्नल संबंध

  • Microsoft C Language Reference: Storage-Class Specifiers for External-Level Declarations
  • "The C Standard (C99 with Technical corrigenda TC1, TC2, and TC3 included)" (PDF). (3.61 MiB). In particular, see sections 6.2.2 (Linkage of identifiers), 6.2.4 (Storage duration of objects), 6.7.1 (Storage-class specifiers) and 6.9 (External definitions).