ब्लॉक (प्रोग्रामिंग): Difference between revisions

From Vigyanwiki
(Text)
No edit summary
Line 3: Line 3:
[[कंप्यूटर प्रोग्रामिंग]] में, एक ब्लॉक या कोड ब्लॉक या ब्लॉक का कोड स्रोत कोड की एक लेक्सिकल संरचना है जिसे एक साथ समूहीकृत किया जाता है। ब्लॉक में एक या अधिक [[घोषणा (कंप्यूटर प्रोग्रामिंग)|डिक्लेरेशन]] और [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्स]] होते हैं। एक [[प्रोग्रामिंग भाषा]] जो अन्य ब्लॉकों के भीतर ब्लॉक [[नेस्टिंग (कंप्यूटिंग)|नेस्टिंग]] सहित ब्लॉक के निर्माण की अनुमति देती है, उसे ब्लॉक-[[संरचित प्रोग्रामिंग]] भाषा कहा जाता है। ब्लॉक संरचित प्रोग्रामिंग के लिए मूलभूत हैं, जहां ब्लॉक से [[नियंत्रण संरचना|कन्ट्रोल स्ट्रक्चर]] बनती हैं।
[[कंप्यूटर प्रोग्रामिंग]] में, एक ब्लॉक या कोड ब्लॉक या ब्लॉक का कोड स्रोत कोड की एक लेक्सिकल संरचना है जिसे एक साथ समूहीकृत किया जाता है। ब्लॉक में एक या अधिक [[घोषणा (कंप्यूटर प्रोग्रामिंग)|डिक्लेरेशन]] और [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्स]] होते हैं। एक [[प्रोग्रामिंग भाषा]] जो अन्य ब्लॉकों के भीतर ब्लॉक [[नेस्टिंग (कंप्यूटिंग)|नेस्टिंग]] सहित ब्लॉक के निर्माण की अनुमति देती है, उसे ब्लॉक-[[संरचित प्रोग्रामिंग]] भाषा कहा जाता है। ब्लॉक संरचित प्रोग्रामिंग के लिए मूलभूत हैं, जहां ब्लॉक से [[नियंत्रण संरचना|कन्ट्रोल स्ट्रक्चर]] बनती हैं।


ब्लॉक के दो फंक्शन्स हैं: [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्स]] को समूहित करना ताकि उन्हें एक [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्]] के रूप में माना जा सके, और [[नाम बंधन|नाम स्कोप]] को परिभाषित करना ताकि उन्हें उसी नाम से अलग किया जा सके जो कहीं और उपयोग किया गया हो। एक ब्लॉक-संरचित प्रोग्रामिंग भाषा में, बाहरी ब्लॉकों में नामित ऑब्जेक्ट आंतरिक ब्लॉकों के अंदर दिखाई देते हैं, जब तक कि वे उसी नाम से डिक्लेअर ऑब्जेक्ट द्वारा [[नाम मास्किंग|मास्किंग]] न हों।
ब्लॉक के दो फंक्शन्स हैं: [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्स]] को समूहित करना ताकि उन्हें एक [[बयान (कंप्यूटर विज्ञान)|स्टेटमेंट्]] के रूप में माना जा सके, और [[नाम बंधन|नाम स्कोप]] को परिभाषित करना ताकि उन्हें उसी नाम से अलग किया जा सके जो कहीं और उपयोग किया गया हो। एक ब्लॉक-संरचित प्रोग्रामिंग भाषा में, बाहरी ब्लॉकों में नामित ऑब्जेक्ट आंतरिक ब्लॉकों के अंदर दिखाई देते हैं, जब तक कि वे उसी नाम से डिक्लेअर ऑब्जेक्ट द्वारा [[नाम मास्किंग|मास्किंग]] न हों।


== इतिहास ==
== इतिहास ==
ब्लॉक संरचना के विचार 1950 के दशक में पहले [[ऑटोकोड]] के विकास के दौरान विकसित किए गए थे, और उन्हें [[एल्गोल 58]] और एल्गोल 60 विवरण में औपचारिक रूप दिया गया था। एल्गोल 58 ने "कंपाउंड स्टेटमेंट्" की धारणा प्रस्तावित की, जो केवल पूरी तरह से कन्ट्रोल फ्लो से संबंधित थी। बाद की संशोधित विवरण जिसमें अल्गोल 60 के सिंटेक्स और सिमेंटिक का वर्णन किया गया है, एक ब्लॉक और [[ब्लॉक गुंजाइश|ब्लॉक स्कोप]] की धारणा को प्रस्तावित करता है, जिसमें एक ब्लॉक होता है जिसमें डिक्लेरेशन का एक क्रम होता है, "जिसके बाद स्टेटमेंट्स का एक क्रम होता है और प्रारंभ और अंत के बीच संलग्न होता है।" जिसमें ["e"]very डिक्लेरेशन एक ब्लॉक में इस तरह से प्रकट होती है और केवल उस ब्लॉक के लिए मान्य होती है।
ब्लॉक संरचना के विचार 1950 के दशक में पहले [[ऑटोकोड]] के विकास के दौरान विकसित किए गए थे, और उन्हें [[एल्गोल 58]] और एल्गोल 60 विवरण में औपचारिक रूप दिया गया था। एल्गोल 58 ने "कंपाउंड स्टेटमेंट्" की धारणा प्रस्तावित की, जो केवल पूरी तरह से कन्ट्रोल फ्लो से संबंधित थी। बाद की संशोधित विवरण जिसमें अल्गोल 60 के सिंटेक्स और सिमेंटिक का वर्णन किया गया है, एक ब्लॉक और [[ब्लॉक गुंजाइश|ब्लॉक स्कोप]] की धारणा को प्रस्तावित करता है, जिसमें एक ब्लॉक होता है जिसमें डिक्लेरेशन का एक क्रम होता है, "जिसके बाद स्टेटमेंट्स का एक क्रम होता है और प्रारंभ और अंत के बीच संलग्न होता है।" जिसमें ["e"]very डिक्लेरेशन एक ब्लॉक में इस तरह से प्रकट होती है और केवल उस ब्लॉक के लिए मान्य होती है।


== सिंटेक्स ==
== सिंटेक्स ==
Line 19: Line 19:


== सीमाएं ==
== सीमाएं ==
कुछ भाषाएँ जो डिक्लेरेशन के साथ ब्लॉक का समर्थन करती हैं, वे सभी डेक्लरेशंस का पूर्ण समर्थन नहीं करती हैं; उदाहरण के लिए कई सी-व्युत्पन्न भाषाएँ एक ब्लॉक ([[नेस्टेड समारोह|नेस्टेड फंक्शन्स]] ) के भीतर फ़ंक्शन परिभाषा की अनुमति नहीं देती हैं। और अपने पूर्वज अल्गोल के विपरीत, पास्कल किसी मौजूदा ब्लॉक के आरंभ और अंत के अंदर अपनी स्वयं की डेक्लरेशंस के साथ ब्लॉक के उपयोग का समर्थन नहीं करता है, केवल कंपाउंड स्टेटमेंट्स से स्टेटमेंट्स के अनुक्रम को एक साथ समूहीकृत किया जा सकता है इफ, वाहील, रिपीट और अन्य नियंत्रण स्टेटमेंट्स।  
कुछ भाषाएँ जो डिक्लेरेशन के साथ ब्लॉक का समर्थन करती हैं, वे सभी डेक्लरेशंस का पूर्ण समर्थन नहीं करती हैं; उदाहरण के लिए कई सी-व्युत्पन्न भाषाएँ एक ब्लॉक ([[नेस्टेड समारोह|नेस्टेड फंक्शन्स]]) के भीतर फ़ंक्शन परिभाषा की अनुमति नहीं देती हैं। और अपने पूर्वज अल्गोल के विपरीत, पास्कल किसी मौजूदा ब्लॉक के आरंभ और अंत के अंदर अपनी स्वयं की डेक्लरेशंस के साथ ब्लॉक के उपयोग का समर्थन नहीं करता है, केवल कंपाउंड स्टेटमेंट्स से स्टेटमेंट्स के अनुक्रम को एक साथ समूहीकृत किया जा सकता है इफ, वाहील, रिपीट और अन्य नियंत्रण स्टेटमेंट्स।  


== मूल शब्दार्थ ==
== मूल शब्दार्थ ==
Line 25: Line 25:


[[फोरट्रान चतुर्थ]] और [[बुनियादी|बेसिक]] जैसी आरम्भिक भाषाओं में, कोई स्टेटमेंट ब्लॉक या कंट्रोल स्ट्रक्चर नहीं थे। कंडीशनल [[के लिए जाओ|के लिए कंडीशनल गो टू]] स्टेटमेंट्स का उपयोग करके लागू किए गए थे:
[[फोरट्रान चतुर्थ]] और [[बुनियादी|बेसिक]] जैसी आरम्भिक भाषाओं में, कोई स्टेटमेंट ब्लॉक या कंट्रोल स्ट्रक्चर नहीं थे। कंडीशनल [[के लिए जाओ|के लिए कंडीशनल गो टू]] स्टेटमेंट्स का उपयोग करके लागू किए गए थे:
      C     LANGUAGE: ANSI STANDARD FORTRAN 66
    C   LANGUAGE: ANSI STANDARD FORTRAN 66


  C     INITIALIZE VALUES TO BE CALCULATED
  C   INITIALIZE VALUES TO BE CALCULATED
      PAYSTX = .FALSE.
    PAYSTX = .FALSE.
      PAYSST = .FALSE.
    PAYSST = .FALSE.
      TAX = 0.0
    TAX = 0.0
      SUPTAX = 0.0
    SUPTAX = 0.0
  C     SKIP TAX DEDUCTION IF EMPLOYEE EARNS LESS THAN TAX THRESHOLD
  C   SKIP TAX DEDUCTION IF EMPLOYEE EARNS LESS THAN TAX THRESHOLD
      IF (WAGES .LE. TAXTHR) GOTO 100
    IF (WAGES .LE. TAXTHR) GOTO 100
      PAYSTX = .TRUE.
    PAYSTX = .TRUE.
      TAX = (WAGES - TAXTHR) * BASCRT
    TAX = (WAGES - TAXTHR) * BASCRT
  C     SKIP SUPERTAX DEDUCTION IF EMPLOYEE EARNS LESS THAN SUPERTAX THRESHOLD
  C   SKIP SUPERTAX DEDUCTION IF EMPLOYEE EARNS LESS THAN SUPERTAX THRESHOLD
      IF (WAGES .LE. SUPTHR) GOTO 100
    IF (WAGES .LE. SUPTHR) GOTO 100
      PAYSST = .TRUE.
    PAYSST = .TRUE.
      SUPTAX = (WAGES - SUPTHR) * SUPRAT
    SUPTAX = (WAGES - SUPTHR) * SUPRAT
  100 TAXED = WAGES - TAX - SUPTAX
  100 TAXED = WAGES - TAX - SUPTAX
प्रोग्राम की तार्किक संरचना भाषा में परिलक्षित नहीं होती है, और जब किसी दिए गए कथन को निष्पादित किया जाता है तो उसका विश्लेषण करना कठिन हो सकता है।
प्रोग्राम की तार्किक संरचना भाषा में परिलक्षित नहीं होती है, और जब किसी दिए गए कथन को निष्पादित किया जाता है तो उसका विश्लेषण करना कठिन हो सकता है।


ब्लॉक प्रोग्रामर को बयानों के एक समूह को एक इकाई के रूप में व्यवहार करने की अनुमति देते हैं, और पूर्व निर्धारित मान जो प्रोग्रामिंग की इस शैली में आरंभीकरण में प्रकट होते हैं, उन्हें ब्लॉक संरचना के साथ, निर्णय के नज़दीक रखा जा सकता है:
ब्लॉक प्रोग्रामर को बयानों के एक समूह को एक इकाई के रूप में व्यवहार करने की अनुमति देते हैं, और पूर्व निर्धारित मान जो प्रोग्रामिंग की इस शैली में आरंभीकरण में प्रकट होते हैं, उन्हें ब्लॉक संरचना के साथ, निर्णय के नज़दीक रखा जा सकता है:
      { Language: Jensen and Wirth Pascal }
    { Language: Jensen and Wirth Pascal }


    if wages > tax_threshold then
  if wages > tax_threshold then
        begin
    begin
        paystax := true;
    paystaxa:= true;
        tax := (wages - tax_threshold) * tax_rate
    taxt:= (wages - tax_threshold) * tax_rate
        { The block structure makes it easier to see how the code could
    { The block structure makes it easier to see how the code could
          be refactored for clarity, and also makes it easier to do,
      be refactored for clarity, and also makes it easier to do,
          because the structure of the inner conditional can easily be moved
      because the structure of the inner conditional can easily be moved
          out of the outer conditional altogether and the effects of doing
      out of the outer conditional altogether and the effects of doing
          so are easily predicted. }
      so are easily predicted. }
        if wages > supertax_threshold then begin
    if wages > supertax_threshold then begin
            pays_supertax := true;
      pays_supertaxs:= true;
            supertax := (wages - supertax_threshold) * supertax_rate
      supertax := (wages - supertax_threshold) * supertax_rate
        end
        else begin
            pays_supertax := false;
            supertax := 0
        end
     end
     end
     else begin
     else begin
        paystax := false; pays_supertax := false;
      pays_supertax := false;
        tax := 0; supertax := 0
      supertax := 0
    end;
    end
    taxed := wages - tax - supertax;
  end
  else begin
    paystaxi:= false; pays_supertaxa:= false;
    tax := 0; supertax := 0
  end;
  taxed0:= wages - tax - supertax;
[[पास्कल (प्रोग्रामिंग भाषा)|पास्कल]] के उपरोक्त खंड में ब्लॉक का उपयोग प्रोग्रामर के उद्देश्य को स्पष्ट करता है, और परिणामी ब्लॉक को [[सशर्त (कंप्यूटर प्रोग्रामिंग)|कंडीशनल]] स्टेटमेंट के नेस्टेड पदानुक्रम में संयोजित करने में सक्षम बनाता है। कोड की संरचना प्रोग्रामर की सोच को अधिक ध्यानपूर्वक दर्शाती है, जिससे इसे समझना और संशोधित करना आसान हो जाता है।
[[पास्कल (प्रोग्रामिंग भाषा)|पास्कल]] के उपरोक्त खंड में ब्लॉक का उपयोग प्रोग्रामर के उद्देश्य को स्पष्ट करता है, और परिणामी ब्लॉक को [[सशर्त (कंप्यूटर प्रोग्रामिंग)|कंडीशनल]] स्टेटमेंट के नेस्टेड पदानुक्रम में संयोजित करने में सक्षम बनाता है। कोड की संरचना प्रोग्रामर की सोच को अधिक ध्यानपूर्वक दर्शाती है, जिससे इसे समझना और संशोधित करना आसान हो जाता है।


Line 77: Line 77:


  (let ((empno (ssn-of employee-name)))
  (let ((empno (ssn-of employee-name)))
  (while (is-manager empno)
  (while (is-manager empno)
    (let ((employees (length (underlings-of empno))))
  (let ((employees (length (underlings-of empno))))
      (printf "~a has ~a employees working under him:~%" employee-name employees)
    (printf "~a has ~a employees working under him:~%" employee-name employees)
      (for-each
    (for-each
        (lambda (empno)
    (lambda (empno)
          ;; Within this lambda expression the variable empno refers to the ssn
      ;; Within this lambda expression the variable empno refers to the ssn
          ;; of an underling. The variable empno in the outer expression,
      ;; of an underling. The variable empno in the outer expression,
          ;; referring to the manager's ssn, is shadowed.
      ;; referring to the manager's ssn, is shadowed.
          (printf "Name: ~a, role: ~a~%"
      (printf "Name: ~a, role: ~a~%"
                  (name-of empno)
          (name-of empno)
                  (role-of empno)))
          (role-of empno)))
        (underlings-of empno)))))
    (underlings-of empno)))))
उपरोक्त योजना के खंड में, एम्पो का उपयोग प्रबंधक और उनके अधीनस्थ दोनों को उनके संबंधित ssn द्वारा पहचानने के लिए किया जाता है, लेकिन क्योंकि अधीनस्थ ssn को एक आंतरिक ब्लॉक के भीतर डिक्लेअर किया जाता है, यह उसी नाम के वेरिएबल के साथ अन्तःक्रिया नहीं करता है प्रबंधक का एसएसएन निहित है। व्यवहार में, स्पष्टता के विचार संभवतः प्रोग्रामर को अलग-अलग वेरिएबल नाम चुनने के लिए प्रेरित करेंगे, लेकिन उनके पास विकल्प है और अनजाने में त्रुटि को प्रस्तावित करना अधिक कठिन है।
उपरोक्त योजना के खंड में, एम्पो का उपयोग प्रबंधक और उनके अधीनस्थ दोनों को उनके संबंधित ssn द्वारा पहचानने के लिए किया जाता है, लेकिन क्योंकि अधीनस्थ ssn को एक आंतरिक ब्लॉक के भीतर डिक्लेअर किया जाता है, यह उसी नाम के वेरिएबल के साथ अन्तःक्रिया नहीं करता है प्रबंधक का एसएसएन निहित है। व्यवहार में, स्पष्टता के विचार संभवतः प्रोग्रामर को अलग-अलग वेरिएबल नाम चुनने के लिए प्रेरित करेंगे, लेकिन उनके पास विकल्प है और अनजाने में त्रुटि को प्रस्तावित करना अधिक कठिन है।



Revision as of 10:33, 13 March 2023

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

ब्लॉक के दो फंक्शन्स हैं: स्टेटमेंट्स को समूहित करना ताकि उन्हें एक स्टेटमेंट् के रूप में माना जा सके, और नाम स्कोप को परिभाषित करना ताकि उन्हें उसी नाम से अलग किया जा सके जो कहीं और उपयोग किया गया हो। एक ब्लॉक-संरचित प्रोग्रामिंग भाषा में, बाहरी ब्लॉकों में नामित ऑब्जेक्ट आंतरिक ब्लॉकों के अंदर दिखाई देते हैं, जब तक कि वे उसी नाम से डिक्लेअर ऑब्जेक्ट द्वारा मास्किंग न हों।

इतिहास

ब्लॉक संरचना के विचार 1950 के दशक में पहले ऑटोकोड के विकास के दौरान विकसित किए गए थे, और उन्हें एल्गोल 58 और एल्गोल 60 विवरण में औपचारिक रूप दिया गया था। एल्गोल 58 ने "कंपाउंड स्टेटमेंट्" की धारणा प्रस्तावित की, जो केवल पूरी तरह से कन्ट्रोल फ्लो से संबंधित थी। बाद की संशोधित विवरण जिसमें अल्गोल 60 के सिंटेक्स और सिमेंटिक का वर्णन किया गया है, एक ब्लॉक और ब्लॉक स्कोप की धारणा को प्रस्तावित करता है, जिसमें एक ब्लॉक होता है जिसमें डिक्लेरेशन का एक क्रम होता है, "जिसके बाद स्टेटमेंट्स का एक क्रम होता है और प्रारंभ और अंत के बीच संलग्न होता है।" जिसमें ["e"]very डिक्लेरेशन एक ब्लॉक में इस तरह से प्रकट होती है और केवल उस ब्लॉक के लिए मान्य होती है।

सिंटेक्स

ब्लॉक अलग-अलग भाषाओं में अलग-अलग सिंटैक्स का उपयोग करते हैं। दो व्यापक परिवार हैं:

  • एल्गोल परिवार जिसमें ब्लॉक "begin"और"end"या उसके बराबर को कीवर्ड द्वारा सीमांकित किया गया है। C में, ब्लॉक को कर्ली ब्रेसेस(मझला कोष्ठकों) द्वारा सीमांकित किया जाता है -{और}. एल्गोल 68 कोष्ठकों का उपयोग करता है।
  • कोष्ठक -(और), MS-DOS बैच भाषा में उपयोग किए जाते हैं
  • इंडेंटेशन, जैसा कि पायथन में है
  • एस-एक्सप्रेशन जैसे सिंटैक्टिक कीवर्ड के साथ prog या let (जैसा कि लिस्प परिवार में है)
  • 1968 में (एल्गोल 68 के साथ), फिरएडस्गेर डब्ल्यू. डिजकस्रा की 1974 में गार्डेड कमांड भाषा में सशर्त और पुनरावृत्त कोड ब्लॉक को वैकल्पिक रूप से ब्लॉक आरक्षित शब्द के साथ समाप्त कर दिया गया: उदा। if ~ then ~ elif ~ else ~ fi, case ~ in ~ out ~ esac और for ~ while ~ do ~ od


सीमाएं

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

मूल शब्दार्थ

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

फोरट्रान चतुर्थ और बेसिक जैसी आरम्भिक भाषाओं में, कोई स्टेटमेंट ब्लॉक या कंट्रोल स्ट्रक्चर नहीं थे। कंडीशनल के लिए कंडीशनल गो टू स्टेटमेंट्स का उपयोग करके लागू किए गए थे:

   C   LANGUAGE: ANSI STANDARD FORTRAN 66
C   INITIALIZE VALUES TO BE CALCULATED
   PAYSTX = .FALSE.
   PAYSST = .FALSE.
   TAX = 0.0
   SUPTAX = 0.0
C   SKIP TAX DEDUCTION IF EMPLOYEE EARNS LESS THAN TAX THRESHOLD
   IF (WAGES .LE. TAXTHR) GOTO 100
   PAYSTX = .TRUE.
   TAX = (WAGES - TAXTHR) * BASCRT
C   SKIP SUPERTAX DEDUCTION IF EMPLOYEE EARNS LESS THAN SUPERTAX THRESHOLD
   IF (WAGES .LE. SUPTHR) GOTO 100
   PAYSST = .TRUE.
   SUPTAX = (WAGES - SUPTHR) * SUPRAT
 100 TAXED = WAGES - TAX - SUPTAX

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

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

   { Language: Jensen and Wirth Pascal }
  if wages > tax_threshold then
    begin
    paystaxa:= true;
    taxt:= (wages - tax_threshold) * tax_rate
    { The block structure makes it easier to see how the code could
     be refactored for clarity, and also makes it easier to do,
     because the structure of the inner conditional can easily be moved
     out of the outer conditional altogether and the effects of doing
     so are easily predicted. }
    if wages > supertax_threshold then begin
      pays_supertaxs:= true;
      supertax := (wages - supertax_threshold) * supertax_rate
    end
    else begin
      pays_supertax := false;
      supertax := 0
    end
  end
  else begin
    paystaxi:= false; pays_supertaxa:= false;
    tax := 0; supertax := 0
  end;
  taxed0:= wages - tax - supertax;

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

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

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

 ;; Language: R5RS Standard Scheme
(let ((empno (ssn-of employee-name)))
 (while (is-manager empno)
  (let ((employees (length (underlings-of empno))))
   (printf "~a has ~a employees working under him:~%" employee-name employees)
   (for-each
    (lambda (empno)
      ;; Within this lambda expression the variable empno refers to the ssn
      ;; of an underling. The variable empno in the outer expression,
      ;; referring to the manager's ssn, is shadowed.
     (printf "Name: ~a, role: ~a~%"
         (name-of empno)
         (role-of empno)))
    (underlings-of empno)))))

उपरोक्त योजना के खंड में, एम्पो का उपयोग प्रबंधक और उनके अधीनस्थ दोनों को उनके संबंधित ssn द्वारा पहचानने के लिए किया जाता है, लेकिन क्योंकि अधीनस्थ ssn को एक आंतरिक ब्लॉक के भीतर डिक्लेअर किया जाता है, यह उसी नाम के वेरिएबल के साथ अन्तःक्रिया नहीं करता है प्रबंधक का एसएसएन निहित है। व्यवहार में, स्पष्टता के विचार संभवतः प्रोग्रामर को अलग-अलग वेरिएबल नाम चुनने के लिए प्रेरित करेंगे, लेकिन उनके पास विकल्प है और अनजाने में त्रुटि को प्रस्तावित करना अधिक कठिन है।

उत्थापन

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

यह भी देखें

संदर्भ