स्टेटमेंट (कंप्यूटर विज्ञान)

कंप्यूटर प्रोग्रामिंग में, स्टेटमेंट एक अनिवार्य प्रोग्रामिंग की सिंटेक्स (प्रोग्रामिंग लैंग्वेज) इकाई है जो कुछ क्रियाओं को करने के लिए व्यक्त करती है। ऐसी भाषा में लिखा गया कंप्यूटर प्रोग्राम एक या एक से अधिक कथनों के अनुक्रम से बनता है। एक बयान में आंतरिक घटक हो सकते हैं (जैसे अभिव्यक्ति (कंप्यूटर विज्ञान))।

कई प्रोग्रामिंग लैंग्वेज (जैसे Ada (प्रोग्रामिंग लैंग्वेज), ऐल्गॉल 60, C (प्रोग्रामिंग लैंग्वेज), जावा (प्रोग्रामिंग लैंग्वेज),  पास्कल (प्रोग्रामिंग भाषा) ) स्टेटमेंट्स और डिक्लेरेशन (कंप्यूटर प्रोग्रामिंग) | डेफिनिशन / डिक्लेरेशन के बीच अंतर करती हैं। एक परिभाषा या घोषणा उस डेटा को निर्दिष्ट करती है जिस पर एक प्रोग्राम संचालित होता है, जबकि एक बयान उस डेटा के साथ की जाने वाली कार्रवाइयों को निर्दिष्ट करता है।

जिन कथनों में अन्य कथन नहीं हो सकते वे सरल हैं; जिनमें अन्य कथन हो सकते हैं वे यौगिक हैं। एक कथन (और वास्तव में एक कार्यक्रम) की उपस्थिति उसके सिंटेक्स (प्रोग्रामिंग भाषाओं) या व्याकरण द्वारा निर्धारित की जाती है। एक कथन का अर्थ उसके शब्दार्थ (कंप्यूटर विज्ञान) द्वारा निर्धारित किया जाता है।

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


 * असाइनमेंट (कंप्यूटर विज्ञान)
 * फोरट्रान:
 * पास्कल, अल्गोल 60, एडीए:
 * सी, सी#, सी++, पीएचपी, जावा:
 * सबरूटीन
 * फोरट्रान:
 * सी, सी++, जावा, पीएचपी, पास्कल, अदा:
 * अभिकथन (सॉफ्टवेयर विकास)
 * सी, सी++, पीएचपी:
 * जावा:
 * के लिए जाओ
 * फोरट्रान:
 * अल्गोल 60:
 * सी, सी++, पीएचपी, पास्कल:
 * रिटर्न स्टेटमेंट
 * फोरट्रान:
 * सी, सी++, जावा, पीएचपी:
 * बाहर निकलें (सिस्टम कॉल) | रोकें/रोकें/बाहर निकलें
 * फोरट्रान:
 * सी, सी++:
 * पीएचपी:

यौगिक कथन
कंपाउंड स्टेटमेंट में (सीक्वेंस) स्टेटमेंट्स हो सकते हैं, जो किसी भी उचित गहराई तक नेस्टेबल होते हैं, और सामान्यतः इन निहित स्टेटमेंट्स को मानने या न दोहराने का फैसला करने के लिए टेस्ट शामिल होते हैं।


 * निम्नलिखित उदाहरणों के लिए संकेतन:
 * <कथन> कोई एकल कथन है (सरल या मिश्रित हो सकता है)।
 * <अनुक्रम> शून्य या अधिक <कथन> का कोई अनुक्रम है
 * कुछ प्रोग्रामिंग लैंग्वेज स्टेटमेंट्स को एक साथ समूहीकृत करने का एक सामान्य तरीका प्रदान करती हैं, ताकि किसी एक <कथन> को एक समूह द्वारा प्रतिस्थापित किया जा सके:


 * अल्गोल 60:
 * पास्कल:
 * सी, पीएचपी, जावा:
 * अन्य प्रोग्रामिंग भाषाओं में प्रत्येक प्रकार के यौगिक कथन पर एक अलग विशेष टर्मिनेटर होता है, ताकि एक या अधिक कथन स्वचालित रूप से एक समूह के रूप में माने जा सकें:
 * अदा:

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


 * लूप के लिए | काउंट-नियंत्रित लूप:
 * अल्गोल 60:
 * पास्कल:
 * सी, जावा:
 * वहाँ है:
 * फोरट्रान 90:


 * जबकि लूप|लूप की शुरुआत में परीक्षण के साथ स्थिति-नियंत्रित लूप:
 * अल्गोल 60:
 * पास्कल:
 * सी, जावा:
 * वहाँ है:
 * फोरट्रान 90:
 * लूप करते समय करें | लूप के अंत में परीक्षण के साथ स्थिति-नियंत्रित लूप:
 * पास्कल:  ** सी, जावा:
 * वहाँ है:
 * लूप के बीच में परीक्षण के साथ स्थिति-नियंत्रित लूप:
 * सी:
 * वहाँ है:
 * सशर्त (प्रोग्रामिंग)|अगर-कथन सरल स्थिति:
 * अल्गोल 60:
 * पास्कल:
 * सी, जावा:
 * वहाँ है:
 * फोरट्रान 77+:


 * सशर्त (प्रोग्रामिंग) | यदि-कथन दो तरफा विकल्प:
 * अल्गोल 60:
 * पास्कल:
 * सी, जावा:
 * वहाँ है:
 * फोरट्रान 77+:
 * स्विच स्टेटमेंट | केस/स्विच स्टेटमेंट मल्टी-वे विकल्प:
 * पास्कल: case c of 'a': alert; 'q': quit; end;
 * वहाँ है: case c is when 'a' => alert; when 'q' => quit; end case;
 * सी, जावा: switch (c) { case 'a': alert; break; case 'q': quit; break; }
 * एक्सेप्शन हेंडलिंग:
 * अदा:
 * जावा:
 * पायथन:

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

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

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

कोई विशिष्ट कीवर्ड नहीं
फोरट्रान और पीएल/1 में आरक्षित कीवर्ड नहीं हैं, जैसे बयानों की अनुमति:


 * पीएल/1 में:
 * (दूसरा  और पहला   चर हैं)।
 * फोरट्रान में:
 * सशर्त बयान (अन्य रूपों के साथ)
 * नामित एक सबस्क्रिप्टेड चर के लिए असाइनमेंट
 * चूंकि फोरट्रान 95 तक रिक्त स्थान वैकल्पिक थे, एक टाइपो पूरी तरह से एक कथन का अर्थ बदल सकता है:
 * I के साथ एक लूप की शुरुआत 1 से 5 तक चल रही है
 * चर को मान 1.5 का असाइनमेंट

ध्वजांकित शब्द
Algol 60 और Algol 68 में, विशेष टोकन स्पष्ट रूप से प्रतिष्ठित थे: प्रकाशन के लिए, बोल्डफेस में उदा। ; प्रोग्रामिंग के लिए, कुछ विशेष अंकन के साथ, उदाहरण के लिए, एक ध्वज, उद्धरण चिह्न , या रेखांकित (  इलियट 503 पर)। इसे स्ट्रॉपिंग कहा जाता है।

टोकन जो भाषा सिंटैक्स का हिस्सा हैं, इस प्रकार प्रोग्रामर-परिभाषित नामों के साथ संघर्ष नहीं करते हैं।

आरक्षित कीवर्ड
कुछ नाम प्रोग्रामिंग भाषा के हिस्से के रूप में आरक्षित हैं और इन्हें प्रोग्रामर-परिभाषित नामों के रूप में उपयोग नहीं किया जा सकता है। अधिकांश लोकप्रिय प्रोग्रामिंग भाषाएं आरक्षित कीवर्ड का उपयोग करती हैं। शुरुआती उदाहरणों में फ्लो-Matic  (1953) और कोबोल (1959) शामिल हैं। 1970 के बाद से अन्य उदाहरणों में एडा, सी, सी++, जावा और पास्कल शामिल हैं। आरक्षित शब्दों की संख्या भाषा पर निर्भर करती है: C में लगभग 30 जबकि COBOL में लगभग 400 हैं।

सिमेंटिक्स
शब्दार्थ एक कार्यक्रम के अर्थ से संबंधित है। कई प्रोग्रामिंग भाषाओं के लिए मानक दस्तावेज़ सिंटैक्स/व्याकरण को काफी औपचारिक और सटीक तरीके से व्यक्त करने के लिए बीएनएफ या कुछ समकक्ष का उपयोग करते हैं, लेकिन कार्यक्रम के शब्दार्थ/अर्थ को सामान्यतः उदाहरणों और अंग्रेजी गद्य का उपयोग करके वर्णित किया जाता है। इसका परिणाम अस्पष्टता हो सकता है। कुछ भाषा विवरणों में यौगिक कथनों का अर्थ 'सरल' निर्माणों के उपयोग से परिभाषित किया गया है, उदा। a while लूप को टेस्ट, जंप और लेबल के संयोजन द्वारा परिभाषित किया जा सकता है  और.

शब्दार्थ (कंप्यूटर विज्ञान) लेख कई गणितीय/तार्किक औपचारिकताओं का वर्णन करता है जिनका उपयोग शब्दार्थ को सटीक तरीके से निर्दिष्ट करने के लिए किया गया है; ये सामान्यतः बीएनएफ की तुलना में अधिक जटिल होते हैं, और सामान्यतः जाने के तरीके के रूप में कोई एकल दृष्टिकोण स्वीकार नहीं किया जाता है। कुछ दृष्टिकोण प्रभावी ढंग से भाषा के लिए एक दुभाषिया को परिभाषित करते हैं, कुछ एक कार्यक्रम के बारे में तर्क के लिए औपचारिक तर्क का उपयोग करते हैं, कुछ निरंतरता सुनिश्चित करने के लिए वाक्यात्मक संस्थाओं को प्रत्यय संलग्न करते हैं, आदि।

भाव
निष्पादित किए गए कथनों और अभिव्यक्ति (प्रोग्रामिंग) के बीच अक्सर अंतर किया जाता है, जिनका मूल्यांकन किया जाता है। भाव हमेशा एक मान का मूल्यांकन करते हैं, जो कथन नहीं करते हैं। हालाँकि, अभिव्यक्तियाँ अक्सर एक बड़े बयान के हिस्से के रूप में उपयोग की जाती हैं।

अधिकांश प्रोग्रामिंग भाषाओं में, एक कथन में एक अभिव्यक्ति की तुलना में थोड़ा अधिक शामिल हो सकता है, सामान्यतः एक कथन टर्मिनेटर (अर्धविराम) के साथ अभिव्यक्ति का अनुसरण करके। ऐसे मामले में, जबकि अभिव्यक्ति एक मूल्य का मूल्यांकन करती है, पूरा बयान नहीं करता है (अभिव्यक्ति का मूल्य छोड़ दिया जाता है)। उदाहरण के लिए, C, C++, C#, और कई समान भाषाओं में,  एक एक्सप्रेशन है जो x को y प्लस वन के मान पर सेट करेगा, और संपूर्ण एक्सप्रेशन स्वयं उसी मान का मूल्यांकन करेगा जिस पर x सेट है। हालाँकि,   (अंत में अर्धविराम पर ध्यान दें) एक बयान है जो अभी भी एक्स को वाई प्लस वन के मान पर सेट करेगा क्योंकि बयान के भीतर अभिव्यक्ति का अभी भी मूल्यांकन किया जाता है, लेकिन अभिव्यक्ति का नतीजा खारिज कर दिया जाता है, और बयान स्वयं का मूल्यांकन नहीं करता है कोई मान। भावों को अन्य भावों में भी समाहित किया जा सकता है। उदाहरण के लिए, अभिव्यक्ति  अभिव्यक्ति समाहित है , जिसमें बदले में मान होते हैं   और  , जो तकनीकी रूप से भाव भी हैं।

हालाँकि पिछले उदाहरण असाइनमेंट एक्सप्रेशन दिखाते हैं, कुछ भाषाएँ असाइनमेंट को एक्सप्रेशन के रूप में नहीं बल्कि एक स्टेटमेंट के रूप में लागू करती हैं। इसका एक उल्लेखनीय उदाहरण पायथन (प्रोग्रामिंग लैंग्वेज) है, जहां = एक ऑपरेटर नहीं है, बल्कि असाइनमेंट स्टेटमेंट में सिर्फ एक विभाजक है। यद्यपि पायथन कई असाइनमेंट की अनुमति देता है क्योंकि प्रत्येक असाइनमेंट एक अभिव्यक्ति थी, यह केवल वास्तविक अभिव्यक्ति के बजाय भाषा व्याकरण में निर्मित असाइनमेंट स्टेटमेंट का एक विशेष मामला है।

एक्स्टेंसिबिलिटी
अधिकांश भाषाओं में भाषा द्वारा परिभाषित बयानों का एक निश्चित सेट होता है, लेकिन विस्तारणीय भाषाओं के साथ प्रयोग किए गए हैं जो प्रोग्रामर को नए बयानों को परिभाषित करने की अनुमति देते हैं।

यह भी देखें

 * प्रोग्रामिंग भाषाओं की तुलना (वाक्यविन्यास) # कथन | प्रोग्रामिंग भाषाओं की तुलना - कथन
 * बहाव को काबू करें
 * अभिव्यक्ति (प्रोग्रामिंग) (विपरीत)

बाहरी संबंध

 * PC ENCYCLOPEDIA: Definition of: program statement