पास्कल - त्वरित गाइड

पास्कल एक सामान्य-उद्देश्य, उच्च-स्तरीय भाषा है जिसे मूल रूप से 1970 के दशक की शुरुआत में निकोलस विर्थ द्वारा विकसित किया गया था। यह एक व्यवस्थित अनुशासन के रूप में प्रोग्रामिंग सिखाने और विश्वसनीय और कुशल कार्यक्रमों को विकसित करने के लिए विकसित किया गया था।

पास्कल अल्गोल-आधारित भाषा है और इसमें अल्गोल के कई निर्माण शामिल हैं। अल्गोल 60 पास्कल का सबसेट है। पास्कल कई डेटा प्रकार और प्रोग्रामिंग संरचनाएं प्रदान करता है। पास्कल कार्यक्रमों को समझना और बनाए रखना आसान है।

पास्कल विभिन्न कारणों से शिक्षण और शिक्षाविदों के क्षेत्र में लोकप्रियता में वृद्धि हुई है:

  • सीखने में आसान।
  • संरचित भाषा।
  • यह पारदर्शी, कुशल और विश्वसनीय कार्यक्रम तैयार करता है।
  • इसे विभिन्न कंप्यूटर प्लेटफॉर्म पर संकलित किया जा सकता है।

पास्कल भाषा की विशेषताएं

पास्कल की निम्नलिखित विशेषताएं हैं -

  • पास्कल एक जोरदार टाइप की गई भाषा है।
  • यह व्यापक त्रुटि जाँच प्रदान करता है।
  • यह कई डेटा प्रकार जैसे सरणियाँ, रिकॉर्ड, फ़ाइलें और सेट प्रदान करता है।
  • यह विभिन्न प्रकार की प्रोग्रामिंग संरचनाएँ प्रदान करता है।
  • यह कार्यों और प्रक्रियाओं के माध्यम से संरचित प्रोग्रामिंग का समर्थन करता है।
  • यह ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग को सपोर्ट करता है।

पास्कल के बारे में तथ्य

  • पास्कल भाषा का नाम ब्लाइस पास्कल, फ्रेंच गणितज्ञ और कंप्यूटर विकास में अग्रणी के लिए रखा गया था।

  • निकलस विर्थ ने 1970 में मूल पास्कल प्रोग्रामिंग भाषा का विकास पूरा किया।

  • पास्कल अल्गोल प्रोग्रामिंग भाषा की ब्लॉक संरचित शैली पर आधारित है।

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

  • आईएसओ 7185 पास्कल स्टैंडर्ड मूल रूप से 1983 में प्रकाशित हुआ था।

  • पास्कल प्राथमिक उच्च-स्तरीय भाषा थी जिसका उपयोग ऐप्पल लिसा में और मैक के शुरुआती वर्षों में विकास के लिए किया गया था।

  • 1986 में, Apple कंप्यूटर ने पहला ऑब्जेक्ट पास्कल कार्यान्वयन जारी किया और 1993 में पास्कल स्टैंडर्ड्स कमेटी ने पास्कल के लिए ऑब्जेक्ट ओरिएंटेड एक्सटेंशन प्रकाशित किया।

पास्कल का उपयोग क्यों करें?

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

पास्कल नेस्टेड प्रक्रिया परिभाषाओं को गहराई के किसी भी स्तर तक ले जाने की अनुमति देता है। यह वास्तव में प्रोग्रामिंग को मौलिक अवधारणाओं के आधार पर व्यवस्थित अनुशासन के रूप में सीखने के लिए एक शानदार प्रोग्रामिंग वातावरण प्रदान करता है।

पास्कल के सबसे आश्चर्यजनक कार्यान्वयनों में से हैं -

  • Skype
  • कुल कमांडर
  • TeX
  • मैक्रोमीडिया कैप्टिनेट
  • Apple लिसा
  • विभिन्न पीसी खेल
  • अंत: स्थापित प्रणाली

सामान्य उपयोग के लिए कई पास्कल संकलक और दुभाषिए उपलब्ध हैं। इनमें से हैं -

  • Turbo Pascal - सीपी / एम, सीपी / एम -86, डॉस, विंडोज और मैक्रोश पर पास्कल प्रोग्राम चलाने के लिए एक आईडीई और कंपाइलर प्रदान करता है।

  • Delphi- ऑब्जेक्ट पास्कल चलाने के लिए कंपाइलर प्रदान करता है और 32- और 64-बिट विंडोज ऑपरेटिंग सिस्टम के लिए देशी कोड और साथ ही 32-बिट मैक ओएस एक्स और आईओएस उत्पन्न करता है। Embarcadero, Linux और Android ऑपरेटिंग सिस्टम के लिए समर्थन बनाने की योजना बना रहा है।

  • Free Pascal- यह पास्कल और ऑब्जेक्ट पास्कल प्रोग्राम चलाने के लिए एक मुफ्त संकलक है। फ्री पास्कल कंपाइलर एक 32- और 64-बिट टर्बो पास्कल है और लिनक्स, विंडोज, ओएस / 2, फ्रीबीएसडी, मैक ओएस एक्स, डॉस और कई अन्य प्लेटफार्मों के लिए डेल्फी संगत पास्कल कंपाइलर है।

  • Turbo51 - यह माइक्रोकंट्रोलर्स के 8051 परिवार के लिए एक मुफ्त पास्कल संकलक है, जिसमें टर्बो पास्कल 7 सिंटेक्स है।

  • Oxygene - यह .NET और मोनो प्लेटफार्मों के लिए एक ऑब्जेक्ट पास्कल संकलक है।

  • GNU Pascal (GPC) - यह एक पास्कल कंपाइलर है जो GNU कंपाइलर कलेक्शन के फ्रंट एंड से बना है।

हम इन ट्यूटोरियल्स में फ्री पास्कल का उपयोग करेंगे। आप लिंक से अपने ऑपरेटिंग सिस्टम के लिए नि: शुल्क पास्कल डाउनलोड कर सकते हैं: नि : शुल्क पास्कल डाउनलोड करें

लिनक्स पर नि: शुल्क पास्कल स्थापित करना

फ्री पास्कल का लिनक्स वितरण तीन रूपों में आता है -

  • tar.gz संस्करण, अलग फ़ाइलों के रूप में भी उपलब्ध है।

  • .rpm (रेड हैट पैकेज मैनेजर) संस्करण।

  • .deb (डेबियन) संस्करण।

.Rpm संस्करण के लिए इंस्टालेशन कोड ::

rpm -i fpc-X.Y.Z-N.ARCH.rpm

जहाँ XYZ .rpm फ़ाइल का संस्करण संख्या है, और ARCH समर्थित आर्किटेक्चर (i386, x86_64, आदि) में से एक है।

डेबियन संस्करण के लिए इंस्टालेशन कोड (जैसे उबंटू) -

dpkg -i fpc-XXX.deb

जहाँ XXX .deb फ़ाइल का संस्करण संख्या है।

विवरण के लिए पढ़ें: नि : शुल्क पास्कल इंस्टॉलेशन गाइड

मैक पर नि: शुल्क पास्कल स्थापित करना

यदि आप मैक ओएस एक्स का उपयोग करते हैं, तो नि: शुल्क पास्कल का उपयोग करने का सबसे आसान तरीका ऐप्पल की वेब साइट से एक्सकोड विकास पर्यावरण को डाउनलोड करना और सरल इंस्टॉलेशन निर्देशों का पालन करना है। एक बार आपके पास Xcode सेटअप होने के बाद, आप Free Pascal कंपाइलर का उपयोग कर पाएंगे।

विंडोज पर फ्री पास्कल इंस्टॉल करना

विंडोज के लिए, आप विंडोज इंस्टॉलर, setup.exe डाउनलोड करेंगे। यह एक सामान्य इंस्टालेशन प्रोग्राम है। स्थापना के लिए आपको निम्नलिखित कदम उठाने होंगे -

  • एक निर्देशिका का चयन करें।

  • उस पैकेज के कुछ हिस्सों का चयन करें जिसे आप इंस्टॉल करना चाहते हैं।

  • वैकल्पिक रूप से नि: शुल्क पास्कल आईडीई के साथ .pp या .pas एक्सटेंशन को जोड़ना।

विवरण के लिए पढ़ें: नि : शुल्क पास्कल इंस्टॉलेशन गाइड

पाठ संपादक

इसका उपयोग आपके प्रोग्राम को टाइप करने के लिए किया जाएगा। कुछ संपादकों के उदाहरणों में विंडोज नोटपैड, ओएस एडिट कमांड, ब्रीफ, एप्सिलॉन, ईएमएसीएस और विम या vi शामिल हैं।

टेक्स्ट एडिटर का नाम और संस्करण अलग-अलग ऑपरेटिंग सिस्टम पर भिन्न हो सकते हैं। उदाहरण के लिए, नोटपैड का उपयोग विंडोज पर किया जाएगा और vim या vi का उपयोग विंडोज़ के साथ-साथ लिनक्स या UNIX पर भी किया जा सकता है।

आपके द्वारा अपने संपादक के साथ बनाई गई फाइलों को सोर्स फाइल कहा जाता है और इसमें प्रोग्राम सोर्स कोड होता है। पास्कल कार्यक्रमों के लिए स्रोत फाइलें आमतौर पर एक्सटेंशन के साथ नामित की जाती हैं.pas

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

पास्कल प्रोग्रामिंग लैंग्वेज के बेसिक बिल्डिंग ब्लॉक्स का अध्ययन करने से पहले, हमें नंगे न्यूनतम पास्कल प्रोग्राम संरचना को देखना चाहिए ताकि हम इसे आगामी अध्यायों में एक संदर्भ के रूप में ले सकें।

पास्कल प्रोग्राम संरचना

एक पास्कल कार्यक्रम मूल रूप से निम्नलिखित भागों के होते हैं -

  • कार्यक्रम का नाम
  • कमांड का उपयोग करता है
  • घोषणाएं लिखें
  • लगातार घोषणाएं
  • चर घोषणा
  • कार्य घोषणा
  • प्रक्रियाएँ घोषणाएँ
  • मुख्य कार्यक्रम ब्लॉक
  • प्रत्येक ब्लॉक के भीतर कथन और अभिव्यक्तियाँ
  • Comments

प्रत्येक पास्कल कार्यक्रम में आम तौर पर एक हेडिंग स्टेटमेंट, एक घोषणा और एक निष्पादन भाग होता है जो उस क्रम में सख्ती से होता है। निम्नलिखित प्रारूप पास्कल कार्यक्रम के लिए मूल सिंटैक्स दिखाता है -

program {name of the program}
uses {comma delimited names of libraries you use}
const {global constant declaration block}
var {global variable declaration block}

function {function declarations, if any}
{ local variables }
begin
...
end;

procedure { procedure declarations, if any}
{ local variables }
begin
...
end;

begin { main program block starts}
...
end. { the end of main program block }

पास्कल हैलो वर्ल्ड उदाहरण

निम्नलिखित एक सरल पास्कल कोड है जो "हैलो, वर्ल्ड!" शब्दों को प्रिंट करेगा। -

program HelloWorld;
uses crt;

(* Here the main program block starts *)
begin
   writeln('Hello, World!');
   readkey;
end.

यह निम्नलिखित परिणाम देगा -

Hello, World!

आइए उपरोक्त कार्यक्रम के विभिन्न भागों को देखें -

  • कार्यक्रम की पहली पंक्ति program HelloWorld; कार्यक्रम का नाम इंगित करता है।

  • कार्यक्रम की दूसरी पंक्ति uses crt; एक प्रीप्रोसेसर कमांड है, जो वास्तविक संकलन में जाने से पहले कंपाइलर को crt यूनिट को शामिल करने के लिए कहता है।

  • आरंभ और अंत विवरणों में संलग्न अगली पंक्तियाँ मुख्य कार्यक्रम खंड हैं। पास्कल में हर ब्लॉक एक के भीतर संलग्न हैbegin कथन और endबयान। हालाँकि, मुख्य कार्यक्रम के अंत का संकेत देने वाला अंतिम विवरण अर्धविराम (;) के बजाय एक पूर्ण विराम (;) है।

  • begin मुख्य कार्यक्रम ब्लॉक का बयान वह है जहां कार्यक्रम का निष्पादन शुरू होता है।

  • भीतर की रेखाएं (*...*) संकलक द्वारा नजरअंदाज कर दिया जाएगा और इसे जोड़ने के लिए रखा गया है comment कार्यक्रम में।

  • बयान writeln('Hello, World!');पास्कल में उपलब्ध रिटेलन फ़ंक्शन का उपयोग करता है जो "हैलो, वर्ल्ड!" संदेश का कारण बनता है। स्क्रीन पर प्रदर्शित किया जाना है।

  • बयान readkey;उपयोगकर्ता को कुंजी दबाने तक प्रदर्शन को रोकने की अनुमति देता है। यह crt यूनिट का हिस्सा है। एक इकाई पास्कल में एक पुस्तकालय की तरह है।

  • आखिरी बयान end. अपने कार्यक्रम को समाप्त करता है।

संकलन और निष्पादन पास्कल कार्यक्रम

  • एक टेक्स्ट एडिटर खोलें और उपर्युक्त कोड जोड़ें।

  • फ़ाइल को hello.pas के रूप में सहेजें

  • कमांड प्रॉम्प्ट खोलें और निर्देशिका में जाएं, जहां आपने फ़ाइल को सहेजा है।

  • कमांड प्रॉम्प्ट पर fpc hello.pas टाइप करें और अपना कोड संकलित करने के लिए एंटर दबाएं।

  • यदि आपके कोड में कोई त्रुटि नहीं है, तो कमांड प्रॉम्प्ट आपको अगली पंक्ति में ले जाएगा और उत्पन्न करेगा hello निष्पादन योग्य फ़ाइल और hello.o ऑब्जेक्ट फ़ाइल।

  • अब, टाइप करें hello अपने प्रोग्राम को निष्पादित करने के लिए कमांड प्रॉम्प्ट पर।

  • आप स्क्रीन पर मुद्रित "हैलो वर्ल्ड" को देख पाएंगे और किसी भी कुंजी को दबाने तक कार्यक्रम का इंतजार करेंगे।

$ fpc hello.pas Free Pascal Compiler version 2.6.0 [2011/12/23] for x86_64 Copyright (c) 1993-2011 by Florian Klaempfl and others Target OS: Linux for x86-64 Compiling hello.pas Linking hello 8 lines compiled, 0.1 sec $ ./hello
Hello, World!

सुनिश्चित करें कि मुक्त पास्कल संकलक fpc आपके रास्ते में है और आप इसे स्रोत फ़ाइल hello.pas युक्त निर्देशिका में चला रहे हैं।

आपने पास्कल प्रोग्राम की एक बुनियादी संरचना देखी है, इसलिए पास्कल प्रोग्रामिंग भाषा के अन्य बुनियादी भवन ब्लॉकों को समझना आसान होगा।

चर

एक चर परिभाषा को एक ब्लॉक शुरुआत में रखा जाता है var कीवर्ड, चर की परिभाषाओं के बाद इस प्रकार है:

var
A_Variable, B_Variable ... : Variable_Type;

फ़ंक्शन के कोड-निकाय के बाहर पास्कल चर घोषित किए जाते हैं, जिसका अर्थ है कि वे भीतर घोषित नहीं किए गए हैं begin तथा end जोड़े, लेकिन वे प्रक्रिया / फ़ंक्शन की परिभाषा के बाद और से पहले घोषित किए जाते हैं beginकीवर्ड। वैश्विक चर के लिए, उन्हें प्रोग्राम हेडर के बाद परिभाषित किया गया है।

कार्य / प्रक्रियाएं

पास्कल में, ए procedure कोई रिटर्न मान और ए के साथ निष्पादित होने वाले निर्देशों का सेट है functionएक वापसी मूल्य के साथ एक प्रक्रिया है। फ़ंक्शन / प्रक्रियाओं की परिभाषा इस प्रकार होगी -

Function Func_Name(params...) : Return_Value;
Procedure Proc_Name(params...);

टिप्पणियाँ

बहुस्तरीय टिप्पणियां घुंघराले कोष्ठक और तारांकन के रूप में संलग्न हैं (* ... *)। पास्कल घुंघराले कोष्ठक {...} के भीतर संलग्न एकल-पंक्ति टिप्पणी की अनुमति देता है।

(* This is a multi-line comments
   and it will span multiple lines. *)

{ This is a single line comment in pascal }

मामले की संवेदनशीलता

पास्कल एक केस नॉन-सेंसिटिव भाषा है, जिसका अर्थ है कि आप किसी भी स्थिति में अपने चर, कार्य और प्रक्रिया को लिख सकते हैं। चरों की तरह A_Variable, a_variable और A_VARIABLE का पास्कल में समान अर्थ है।

पास्कल कथन

पास्कल कार्यक्रम बयान से बने होते हैं। प्रत्येक बयान कार्यक्रम की एक निश्चित नौकरी निर्दिष्ट करता है। इन नौकरियों में घोषणा, असाइनमेंट, डेटा पढ़ना, डेटा लिखना, तार्किक निर्णय लेना, कार्यक्रम प्रवाह नियंत्रण को स्थानांतरित करना, आदि हो सकते हैं।

उदाहरण के लिए -

readln (a, b, c);
s := (a + b + c)/2.0;
area := sqrt(s * (s - a)*(s-b)*(s-c));
writeln(area);

पास्कल में आरक्षित शब्द

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

निम्नलिखित पास्कल में उपलब्ध आरक्षित शब्दों की एक सूची है।

तथा सरणी शुरू मामला स्थिरांक
डिव कर downto अन्य समाप्त
फ़ाइल के लिये समारोह के लिए जाओ अगर
में लेबल आधुनिक शून्य नहीं
का या पैक प्रक्रिया कार्यक्रम
अभिलेख दोहराना सेट फिर सेवा
प्रकार जब तक वर जबकि साथ में

पास्कल में चरित्र सेट और पहचानकर्ता

पास्कल चरित्र सेट के होते हैं -

  • सभी ऊपरी मामले पत्र (AZ)

  • सभी निचले मामले पत्र (az)

  • सभी अंक (0-9)

  • विशेष प्रतीक - + * /: =,। ;। () [] = {} `सफेद स्थान

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

एक इकाई के डेटा प्रकार इसके साथ जुड़े भंडारण के अर्थ, बाधाओं, संभावित मूल्यों, संचालन, कार्यों और मोड को इंगित करते हैं।

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

पास्कल डेटा प्रकार

निम्नलिखित आरेख में पास्कल डेटा प्रकारों को संक्षेप में प्रस्तुत किया जा सकता है -

घोषणाएँ लिखें

प्रकार की घोषणा का उपयोग पहचानकर्ता के डेटा प्रकार को घोषित करने के लिए किया जाता है। प्रकार की घोषणा का सिंटैक्स है -

type-identifier-1, type-identfier-2 = type-specifier;

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

type
days, age = integer;
yes, true = boolean;
name, city = string;
fees, expenses = real;

पूर्णांक प्रकार

निम्नलिखित तालिका आपको ऑब्जेक्ट पास्कल में उपयोग किए जाने वाले भंडारण आकार और मूल्य श्रेणियों के साथ मानक पूर्णांक प्रकारों के बारे में विवरण देती है -

प्रकार न्यूनतम ज्यादा से ज्यादा प्रारूप
पूर्णांक -+२१४७४८३६४८ 2147483647 32-बिट पर हस्ताक्षर किए
कार्डिनल 0 4294967295 अहस्ताक्षरित 32-बिट
Shortint -128 127 8-बिट पर हस्ताक्षर किए
sMALLINT -32,768 32767 16-बिट पर हस्ताक्षर किए
longint -+२१४७४८३६४८ 2147483647 32-बिट पर हस्ताक्षर किए
Int64 -2 ^ 63 2 ^ 63 - 1 64-बिट पर हस्ताक्षर किए
बाइट 0 255 अहस्ताक्षरित 8-बिट
शब्द 0 65535 अहस्ताक्षरित 16-बिट
Longword 0 4294967295 अहस्ताक्षरित 32-बिट

स्थिरांक

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

निरंतर प्रकार की घोषणा का सिंटैक्स निम्नानुसार है -

const
Identifier = contant_value;

निरंतर घोषणाओं के कुछ उदाहरण निम्नलिखित हैं -

VELOCITY_LIGHT = 3.0E=10;
PIE = 3.141592;
NAME = 'Stuart Little';
CHOICE = yes;
OPERATOR = '+';

चर घोषणा से पहले सभी निरंतर घोषणाएं दी जानी चाहिए।

प्रगणित प्रकार

प्रगणित डेटा प्रकार उपयोगकर्ता-परिभाषित डेटा प्रकार हैं। वे मानों को किसी सूची में निर्दिष्ट करने की अनुमति देते हैं। केवल असाइनमेंट ऑपरेटर और रिलेशनल ऑपरेटर को एन्यूमरेटेड डेटा टाइप पर अनुमति दी जाती है। निम्न डेटा प्रकारों को निम्नानुसार घोषित किया जा सकता है -

type
enum-identifier = (item1, item2, item3, ... )

निम्न प्रकार की घोषणाओं के कुछ उदाहरण निम्नलिखित हैं -

type
SUMMER = (April, May, June, July, September);
COLORS = (Red, Green, Blue, Yellow, Magenta, Cyan, Black, White);
TRANSPORT = (Bus, Train, Airplane, Ship);

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

प्रकार व्यवस्थित करें

सुव्यवस्थित प्रकार एक चर को उन मानों को ग्रहण करने की अनुमति देते हैं जो एक निश्चित सीमा के भीतर झूठ बोलते हैं। उदाहरण के लिए, यदि मतदाताओं की आयु 18 से 100 वर्ष के बीच होनी चाहिए, तो एक नामांकित चर को घोषित किया जा सकता है -

var
age: 18 ... 100;

हम अगले भाग में चर घोषणा पर विस्तार से देखेंगे। आप प्रकार की घोषणा का उपयोग करके एक सब्रेंज प्रकार को भी परिभाषित कर सकते हैं। उपप्रकार के प्रकार को घोषित करने के लिए सिंटैक्स इस प्रकार है -

type
subrange-identifier = lower-limit ... upper-limit;

निम्न प्रकार की घोषणाओं के कुछ उदाहरण निम्नलिखित हैं -

const
P = 18;
Q = 90;
type
Number = 1 ... 100;
Value = P ... Q;

सुव्यवस्थित प्रकारों को पहले से परिभाषित एनुमरेटेड प्रकार के सबसेट से बनाया जा सकता है, उदाहरण के लिए -

type
months = (Jan, Feb, Mar, Apr, May, Jun, Jul, Aug, Sep, Oct, Nov, Dec);
Summer = Apr ... Aug;
Winter = Oct ... Dec;

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

एक चर का नाम अक्षरों, अंकों और अंडरस्कोर वर्ण से बना हो सकता है। यह या तो एक पत्र या एक अंडरस्कोर से शुरू होना चाहिए। पास्कल हैnot case-sensitive, इसलिए अपरकेस और लोअरकेस अक्षर का मतलब यहाँ है। पिछले अध्याय में बताए गए मूल प्रकारों के आधार पर, निम्नलिखित मूल चर प्रकार होंगे -

पास्कल में बुनियादी चर

अनु क्रमांक टाइप और विवरण
1

Character

आमतौर पर एक एकल ओकटेट (एक बाइट)। यह एक पूर्णांक प्रकार है।

2

Integer

मशीन के लिए पूर्णांक का सबसे प्राकृतिक आकार।

3

Real

एकल-सटीक फ़्लोटिंग पॉइंट मान।

4

Boolean

सही या गलत तार्किक मान निर्दिष्ट करता है। यह भी एक पूर्णांक प्रकार है।

5

Enumerated

उपयोगकर्ता-परिभाषित सूची निर्दिष्ट करता है।

6

Subrange

वेरिएबल्स का प्रतिनिधित्व करता है, जिनके मूल्य एक सीमा के भीतर हैं।

7

String

पात्रों की एक सरणी संग्रहीत करता है।

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

पास्कल में परिवर्तनीय घोषणा

पास्कल कार्यक्रम में उपयोग करने से पहले सभी चर घोषित किए जाने चाहिए। सभी चर घोषणाओं के बाद var कीवर्ड होते हैं। एक घोषणापत्र चर की एक सूची निर्दिष्ट करता है, उसके बाद एक बृहदान्त्र (:) और प्रकार। परिवर्तनीय घोषणा का सिंटैक्स है -

var
variable_list : type;

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

var
age, weekdays : integer;
taxrate, net_income: real;
choice, isready: boolean;
initials, grade: char;
name, surname : string;

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

type
days, age = integer;
yes, true = boolean;
name, city = string;
fees, expenses = real;

अब, परिभाषित प्रकारों को परिवर्तनीय घोषणाओं में इस्तेमाल किया जा सकता है -

var
weekdays, holidays : days;
choice: yes;
student_name, emp_name : name;
capital: city;
cost: expenses;

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

पास्कल में वैरिएबल इनिशियलाइज़ेशन

चर को एक बृहदान्त्र और बराबर चिह्न के साथ एक मान दिया जाता है, जिसके बाद एक स्थिर अभिव्यक्ति होती है। मान निर्दिष्ट करने का सामान्य रूप है -

variable_name := value;

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

var
variable_name : type = value;

कुछ उदाहरण हैं -

age: integer = 15;
taxrate: real = 0.5;
grade: char = 'A';
name: string = 'John Smith';

आइए एक उदाहरण देखें, जो अब तक चर्चा किए गए विभिन्न प्रकार के चर का उपयोग करता है -

program Greetings;
const
message = ' Welcome to the world of Pascal ';

type
name = string;
var
firstname, surname: name;

begin
   writeln('Please enter your first name: ');
   readln(firstname);
   
   writeln('Please enter your surname: ');
   readln(surname);
   
   writeln;
   writeln(message, ' ', firstname, ' ', surname);
end.

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

Please enter your first name:
John
Please enter your surname:
Smith
Welcome to the world of Pascal John Smith

विविध चर

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

var
var1, var2, ...  : enum-identifier;

जब आपने एक एन्यूमरेटेड प्रकार घोषित किया है, तो आप उस प्रकार के चर घोषित कर सकते हैं। उदाहरण के लिए,

type
months = (January, February, March, April, May, June, July, August, September, October, November, December);
Var
m: months;
...
M := January;

निम्नलिखित उदाहरण अवधारणा को दर्शाता है -

program exEnumeration;
type
beverage = (coffee, tea, milk, water, coke, limejuice);

var
drink:beverage;

begin
   writeln('Which drink do you want?');
   drink := limejuice;
   
   writeln('You can drink ', drink);
end.

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

Which drink do you want?
You can drink limejuice

चर चरें

व्यवस्थित चर के रूप में घोषित किया जाता है -

var
subrange-name : lowerlim ... uperlim;

सबवेरी चर के उदाहरण हैं -

var
marks: 1 ... 100;
grade: 'A' ... 'E';
age: 1 ... 25;

निम्नलिखित कार्यक्रम अवधारणा को दर्शाता है -

program exSubrange;
var
marks: 1 .. 100;
grade: 'A' .. 'E';

begin
   writeln( 'Enter your marks(1 - 100): ');
   readln(marks);
   
   writeln( 'Enter your grade(A - E): ');
   readln(grade);
   
   writeln('Marks: ' , marks, ' Grade: ', grade);
end.

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

Enter your marks(1 - 100): 
100
Enter your grade(A - E):
A
Marks: 100 Grade: A

एक स्थिरांक एक इकाई है जो कार्यक्रम के निष्पादन के दौरान अपरिवर्तित रहता है। पास्कल केवल निम्न प्रकार के स्थिरांक को घोषित करने की अनुमति देता है -

  • साधारण प्रकार के
  • प्रकार सेट करें
  • सूचक प्रकार (लेकिन केवल अनुमत मूल्य निल) है।
  • वास्तविक प्रकार
  • Char
  • String

लगातार घोषणाएं

स्थिरांक घोषित करने के लिए सिंटेक्स इस प्रकार है -

const
identifier = constant_value;

निम्न तालिका कुछ मान्य निरंतर घोषणाओं के उदाहरण प्रदान करती है -

Real type constant

अनु क्रमांक लगातार प्रकार और उदाहरण
1

Ordinal(Integer)type constant

valid_age = 21;

2

Set type constant

स्वर = (ए, ई, आई, ओ, यू) का सेट;

3

Pointer type constant

पी = एनआईएल;

4

e = 2.7182818;

velocity_light = 3.0E + 10;

5

Character type constant

संचालक = '+';

6

String type constant

राष्ट्रपति = 'जॉनी डेप';

निम्नलिखित उदाहरण अवधारणा को दर्शाता है -

program const_circle (input,output);
const
PI = 3.141592654;

var
r, d, c : real;   {variable declaration: radius, dia, circumference}

begin
   writeln('Enter the radius of the circle');
   readln(r);
   
   d := 2 * r;
   c :=  PI * d;
   writeln('The circumference of the circle is ',c:7:2);
end.

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

Enter the radius of the circle
23
The circumference of the circle is 144.51

कार्यक्रम के आउटपुट स्टेटमेंट में फ़ॉर्मेटिंग को ध्यान से देखें। दशमलव चिन्ह के बाद चर c को अंकों की कुल संख्या 7 और 2 अंकों के साथ प्रारूपित किया जाना है। पास्कल ऐसे आउटपुट को संख्यात्मक चर के साथ स्वरूपण की अनुमति देता है।

एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। पास्कल निम्नलिखित प्रकार के ऑपरेटरों को अनुमति देता है -

  • अंकगणितीय आपरेटर
  • संबंधपरक संकारक
  • बूलियन ऑपरेटर्स
  • बिट संचालक
  • ऑपरेटर सेट करें
  • स्ट्रिंग ऑपरेटरों

आइए हम एक-एक करके अंकगणित, संबंधपरक, बूलियन और बिट ऑपरेटरों पर चर्चा करें। हम बाद में सेट ऑपरेटरों और स्ट्रिंग संचालन पर चर्चा करेंगे।

अंकगणितीय आपरेटर

निम्नलिखित तालिका पास्कल द्वारा समर्थित सभी अंकगणितीय ऑपरेटरों को दर्शाती है। चर मान लेंA 10 और चर रखता है B 20 रखती है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
+ दो ऑपरेंड जोड़ता है A + B 30 देगा
- पहले से दूसरे ऑपरेंड को घटाता है A - B देगा -10
* दोनों ऑपरेंड को गुणा करता है A * B 200 देगा
/ विभाजक द्वारा अंशों को विभाजित करता है B / A 2 देगा
% मापांक ऑपरेटर और पूर्णांक विभाजन के बाद शेष ब% ए द 0 दे खेंगे

संबंधपरक संकारक

निम्नलिखित तालिका पास्कल द्वारा समर्थित सभी रिलेशनल ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 रखती है, तो -

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
= जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ, तो स्थिति सच हो जाती है। (ए = बी) सच नहीं है।
<> जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान समान नहीं हैं, तो स्थिति सत्य हो जाती है। (ए <> बी) सच है।
> जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य हो जाती है। (ए> बी) सच नहीं है।
< जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम है, यदि हाँ, तो स्थिति सच हो जाती है। (ए <बी) सच है।
> = जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या बराबर है, यदि हाँ, तो स्थिति सच हो जाती है। (ए> = बी) सच नहीं है।
<= जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम या बराबर है, यदि हाँ, तो स्थिति सच हो जाती है। (ए <= बी) सच है।

बूलियन ऑपरेटर्स

निम्नलिखित तालिका पास्कल भाषा द्वारा समर्थित सभी बूलियन ऑपरेटरों को दिखाती है। ये सभी ऑपरेटर बूलियन ऑपरेंड पर काम करते हैं और बूलियन परिणाम उत्पन्न करते हैं। चर मान लेंA सत्य और परिवर्तनशील है B गलत है, तो -

उदाहरण दिखाएं

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

बिट संचालक

बिटवाइज़ ऑपरेटर बिट पर काम करते हैं और बिट-बाय-बिट ऑपरेशन करते हैं। ये सभी ऑपरेटर पूर्णांक ऑपरेंड पर काम करते हैं और पूर्णांक परिणाम तैयार करते हैं। बिटवाइज़ और (()), बिटवाइज़ या (!) के लिए सत्य तालिका, और बिटवाइज़ नहीं (~) इस प्रकार हैं -

पी क्यू पी क्यू पी | क्यू ~ पी ~ क्ष
0 0 0 0 1 1
0 1 0 1 1 0
1 1 1 1 0 0
1 0 0 1 0 1

मान लें कि ए = 60; और बी = 13; अब द्विआधारी प्रारूप में वे निम्नानुसार होंगे -

ए = 0011 1100

B = 0000 1101

-----------------

A & B = 0000 1100

ए ^ बी = 0011 0001

~ ए = ११०० ००११

पास्कल द्वारा समर्थित बिटवाइज़ ऑपरेटरों को निम्न तालिका में सूचीबद्ध किया गया है। चर ए मान लें 60 और चर बी 13 रखता है, तो:

उदाहरण दिखाएं

ऑपरेटर विवरण उदाहरण
और बाइनरी और ऑपरेटर परिणाम के लिए थोड़ा सा कॉपी करता है यदि यह दोनों ऑपरेंड में मौजूद है। (A & B) 12 देगा, जो 0000 1100 है
| बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। (ए | बी) 61 देगा, जो 0011 1101 है
! बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। इसके समान | ऑपरेटर। (ए! बी) 61 देगा, जो 0011 1101 है
~ बाइनरी ओन्स कंप्लीट ऑपरेटर, एकात्मक है और इसमें 'फ्लिपिंग' बिट्स का प्रभाव होता है। (~ ए) -61 देगा, जो कि हस्ताक्षरित बाइनरी नंबर के कारण 2 के पूरक रूप में 1100 0011 है।
<< बाइनरी लेफ्ट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से छोड़ दिया जाता है। A << 2 240 देगा, जो कि 1111 0000 है
>> बाइनरी राइट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से दाएं स्थानांतरित किया जाता है। A >> 2 15 देगा, जो 0000 1111 है

कृपया ध्यान दें कि पास्कल के विभिन्न कार्यान्वयन बिटवाइज़ ऑपरेटरों में भिन्न हैं। पास्कल, संकलक जो हमने यहां इस्तेमाल किया था, हालांकि, निम्नलिखित बिटवाइज़ ऑपरेटरों का समर्थन करता है -

ऑपरेटर्स संचालन
नहीं बिटवाइज़ नहीं
तथा बिटवाइज़ और
या बिटवार या
XOR बिटवाइज एक्सक्लूसिव OR
shl बिटवाइस शिफ्ट छोड़ दिया
SHR बिटवाइस शिफ्ट सही
<< बिटवाइस शिफ्ट छोड़ दिया
>> बिटवाइस शिफ्ट सही

पास्कल में ऑपरेटर्स प्रिसेंस

ऑपरेटर पूर्वता एक अभिव्यक्ति में शब्दों के समूहीकरण को निर्धारित करता है। यह प्रभावित करता है कि अभिव्यक्ति का मूल्यांकन कैसे किया जाता है। कुछ ऑपरेटरों में अन्य लोगों की तुलना में अधिक पूर्वता है; उदाहरण के लिए, गुणा ऑपरेटर में अतिरिक्त ऑपरेटर की तुलना में अधिक पूर्वता है।

उदाहरण के लिए x = 7 + 3 * 2; यहाँ, x को 13 नहीं, 20 को सौंपा गया है क्योंकि ऑपरेटर * में + से अधिक पूर्वता है, इसलिए यह पहले 3 * 2 के साथ गुणा हो जाता है और फिर 7 में जुड़ जाता है।

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

उदाहरण दिखाएं

ऑपरेटर प्रधानता
~, नहीं, उच्चतम
*, /, div, मॉड, और
|;;, +, -, या,
=, <>, <, <=>,> =, में
या फिर, और फिर सबसे कम

निर्णय लेने की संरचनाओं के लिए आवश्यक है कि प्रोग्रामर एक या एक से अधिक शर्तों को प्रोग्राम द्वारा मूल्यांकन या परीक्षण करने के लिए निर्दिष्ट करे, साथ ही एक स्टेटमेंट या स्टेटमेंट के साथ निष्पादित किया जाए यदि शर्त सही हो, और वैकल्पिक रूप से, अन्य स्टेटमेंट्स को निष्पादित किया जाए, यदि कंडीशन हो झूठा होना तय है।

अधिकांश प्रोग्रामिंग भाषाओं में पाया जाने वाला एक विशिष्ट निर्णय लेने की संरचना का सामान्य रूप निम्नलिखित है -

पास्कल प्रोग्रामिंग भाषा निर्णय लेने के निम्नलिखित प्रकार प्रदान करती है। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।

अनु क्रमांक विवरण और विवरण
1 अगर - तो बयान

एक if - then statement एक या अधिक बयानों के बाद एक बूलियन अभिव्यक्ति के होते हैं।

2 अगर-तो-और बयान

एक if - then statement एक वैकल्पिक द्वारा पीछा किया जा सकता है else statement, जो निष्पादित करता है जब बूलियन अभिव्यक्ति झूठी होती है।

3 बयान दिया तो नेस्टेड

आप एक का उपयोग कर सकते हैं if या else if दूसरे के अंदर बयान if या else if कथन (नों)।

4 मामला बयान

case कथन मानों की सूची के विरुद्ध समानता के लिए एक चर का परीक्षण करने की अनुमति देता है।

5 मामला - और बयान

यह के समान है if-then-else बयान। यहाँ, एelse पद इस प्रकार है case statement

6 नेस्टेड केस स्टेटमेंट

आप एक का उपयोग कर सकते हैं case दूसरे के अंदर बयान case कथन (नों)।

एक स्थिति हो सकती है, जब आपको कई बार कोड के ब्लॉक को निष्पादित करने की आवश्यकता होती है। सामान्य तौर पर, बयानों को क्रमिक रूप से निष्पादित किया जाता है: किसी फ़ंक्शन में पहला कथन पहले निष्पादित किया जाता है, उसके बाद दूसरा, और इसी तरह।

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

एक लूप स्टेटमेंट हमें कई बार स्टेटमेंट या स्टेटमेंट को निष्पादित करने की अनुमति देता है और निम्नलिखित प्रोग्रामिंग भाषाओं में से एक लूप स्टेटमेंट का सामान्य रूप है -

पास्कल प्रोग्रामिंग भाषा लूपिंग आवश्यकताओं को संभालने के लिए निम्न प्रकार के लूप निर्माण प्रदान करती है। उनके विवरण की जांच करने के लिए निम्नलिखित लिंक पर क्लिक करें।

अनु क्रमांक लूप प्रकार और विवरण
1 लूप करते हैं

एक बयान या बयानों के समूह को दोहराता है जबकि किसी दिए गए शर्त सही है। यह लूप बॉडी को निष्पादित करने से पहले स्थिति का परीक्षण करता है।

2 लूप के लिए

कई बार बयानों का क्रम निष्पादित करता है और उस कोड को संक्षिप्त करता है जो लूप चर का प्रबंधन करता है।

3 बार-बार लूप तक

थोड़ी देर के बयान की तरह, सिवाय इसके कि यह लूप बॉडी के अंत में स्थिति का परीक्षण करता है।

4 स्थिर फंदा

आप किसी अन्य के अंदर एक या एक से अधिक लूप का उपयोग कर सकते हैं, जबकि लूप तक दोहरा सकते हैं।

लूप नियंत्रण विवरण

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

पास्कल निम्नलिखित नियंत्रण कथनों का समर्थन करता है। उनके विवरण की जांच करने के लिए निम्नलिखित लिंक पर क्लिक करें।

अनु क्रमांक नियंत्रण विवरण और विवरण
1 तोड़ बयान

टर्मिनेट करता है loop या case स्टेटमेंट और ट्रांसफर को लूप या केस स्टेटमेंट के तुरंत बाद स्टेटमेंट में ट्रांसफर कर देता है।

2 जारी रखें बयान

लूप को उसके शरीर के शेष हिस्से को छोड़ने के लिए कहता है और पुनरावृत्ति करने से पहले तुरंत उसकी स्थिति को फिर से बना देता है।

3 गोटो बयान

लेबल किए गए स्टेटमेंट पर नियंत्रण स्थानांतरित करता है। यद्यपि यह सलाह नहीं दी जाती है कि आपके कार्यक्रम में गोटो बयान का उपयोग किया जाए।

subprograms

एक उपप्रोग्राम एक प्रोग्राम यूनिट / मॉड्यूल है जो एक विशेष कार्य करता है। ये उपप्रोग्राम बड़े कार्यक्रमों को बनाने के लिए संयुक्त होते हैं। इसे मूल रूप से 'मॉड्यूलर डिजाइन' कहा जाता है। एक सबप्रोग्राम को एक सबप्रोग्राम / प्रोग्राम द्वारा आमंत्रित किया जा सकता है, जिसे कॉलिंग प्रोग्राम कहा जाता है।

पास्कल दो प्रकार के उपप्रोग्राम प्रदान करता है -

  • Functions - ये सबप्रोग्राम एक एकल मान लौटाते हैं।

  • Procedures - ये उपप्रोग्राम सीधे मान वापस नहीं करते हैं।

कार्यों

functionबयानों का एक समूह है जो एक साथ एक कार्य करता है। प्रत्येक पास्कल कार्यक्रम में कम से कम एक फ़ंक्शन होता है, जो कि कार्यक्रम ही है, और सभी सबसे तुच्छ कार्यक्रम अतिरिक्त कार्यों को परिभाषित कर सकते हैं।

एक समारोह declarationकंपाइलर को किसी फ़ंक्शन के नाम, रिटर्न टाइप और पैरामीटर्स के बारे में बताता है। एक समारोहdefinition फ़ंक्शन का वास्तविक निकाय प्रदान करता है।

पास्कल मानक पुस्तकालय कई अंतर्निहित कार्यों को प्रदान करता है जिसे आपका प्रोग्राम कॉल कर सकता है। उदाहरण के लिए, फ़ंक्शनAppendStr() दो तार, कार्य करता है New() चर और कई अन्य कार्यों के लिए गतिशील रूप से स्मृति आवंटित करता है।

एक कार्य को परिभाषित करना

पास्कल में, ए functionफ़ंक्शन कीवर्ड का उपयोग करके परिभाषित किया गया है। फ़ंक्शन परिभाषा का सामान्य रूप निम्नानुसार है -

function name(argument(s): type1; argument(s): type2; ...): function_type;
local declarations;

begin
   ...
   < statements >
   ...
   name:= expression;
end;

पास्कल में एक फ़ंक्शन परिभाषा में एक फ़ंक्शन होता है header, स्थानीय declarations और एक समारोह body। फ़ंक्शन हेडर में कीवर्ड फ़ंक्शन और a शामिल होते हैंnameफ़ंक्शन के लिए दिया गया। यहाँ एक समारोह के सभी भागों हैं -

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

    फ़ंक्शन स्टेटमेंट में दिखाई देने वाली औपचारिक पैरामीटर सूची सरल या सबस्क्रिप्ट किए गए चर, सरणियाँ या संरचित चर, या उपप्रकार हो सकती है।

  • Return Type- सभी फ़ंक्शंस को एक मूल्य वापस करना होगा, इसलिए सभी फ़ंक्शंस को एक प्रकार सौंपा जाना चाहिए। function-typeफ़ंक्शन रिटर्न का मान का डेटा प्रकार है। यह मानक, उपयोगकर्ता-परिभाषित स्केलर या सब्रेंज प्रकार हो सकता है लेकिन यह संरचित प्रकार नहीं हो सकता है।

  • Local declarations - स्थानीय घोषणाएँ लेबल, स्थिरांक, चर, कार्य और प्रक्रियाओं के लिए घोषणाओं को संदर्भित करती हैं, जो केवल कार्य के निकाय के लिए अनुप्रयोग हैं।

  • Function Body- फंक्शन बॉडी में स्टेटमेंट्स का एक संग्रह होता है जो परिभाषित करता है कि फ़ंक्शन क्या करता है। इसे हमेशा आरक्षित शब्दों के बीच शुरू और अंत में संलग्न किया जाना चाहिए। यह एक फ़ंक्शन का हिस्सा है, जहां सभी गणना की जाती हैं। टाइप का असाइनमेंट स्टेटमेंट होना चाहिए -name := expression;फ़ंक्शन बॉडी में जो फ़ंक्शन नाम के लिए मान प्रदान करता है। जब फ़ंक्शन निष्पादित किया जाता है तब यह मान दिया जाता है। शरीर में अंतिम वक्तव्य एक अंतिम वक्तव्य होना चाहिए।

निम्नलिखित एक उदाहरण है कि पास्कल में किसी फ़ंक्शन को कैसे परिभाषित किया जाए -

(* function returning the max between two numbers *)
function max(num1, num2: integer): integer;

var
   (* local variable declaration *)
   result: integer;

begin
   if (num1 > num2) then
      result := num1
   
   else
      result := num2;
   max := result;
end;

समारोह घोषणाएँ

एक समारोह declarationकंपाइलर को फ़ंक्शन नाम और फ़ंक्शन को कॉल करने के तरीके के बारे में बताता है। फ़ंक्शन के वास्तविक निकाय को अलग से परिभाषित किया जा सकता है।

एक फ़ंक्शन घोषणा में निम्नलिखित भाग होते हैं -

function name(argument(s): type1; argument(s): type2; ...): function_type;

ऊपर परिभाषित फ़ंक्शन अधिकतम () के लिए, निम्नलिखित फ़ंक्शन घोषणा है -

function max(num1, num2: integer): integer;

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

एक समारोह बुला रहा है

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

किसी फ़ंक्शन को कॉल करने के लिए, आपको बस फ़ंक्शन नाम के साथ आवश्यक पैरामीटर पास करने की आवश्यकता होती है, और यदि फ़ंक्शन एक मान लौटाता है, तो आप लौटे मूल्य को संग्रहीत कर सकते हैं। उपयोग दिखाने के लिए एक सरल उदाहरण निम्नलिखित है -

program exFunction;
var
   a, b, ret : integer;

(*function definition *)
function max(num1, num2: integer): integer;
var
   (* local variable declaration *)
   result: integer;

begin
   if (num1 > num2) then
      result := num1
   
   else
      result := num2;
   max := result;
end;

begin
   a := 100;
   b := 200;
   (* calling a function to get max value *)
   ret := max(a, b);
   
   writeln( 'Max value is : ', ret );
end.

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

Max value is : 200

Procedures उपप्रोग्राम हैं, जो एकल मान वापस करने के बजाय, परिणामों का एक समूह प्राप्त करने की अनुमति देते हैं।

एक प्रक्रिया को परिभाषित करना

पास्कल में, एक प्रक्रिया का उपयोग करके परिभाषित किया गया है procedureकीवर्ड। एक प्रक्रिया परिभाषा का सामान्य रूप निम्नानुसार है -

procedure name(argument(s): type1, argument(s): type 2, ... );
   < local declarations >
begin
   < procedure body >
end;

एक प्रक्रिया definition पास्कल में एक होते हैं header, स्थानीय declarations और एक bodyप्रक्रिया का। प्रक्रिया हेडर में कीवर्ड होते हैंprocedureऔर प्रक्रिया को दिया गया एक नाम है। यहाँ एक प्रक्रिया के सभी भाग हैं -

  • Arguments- तर्क (एस) कॉलिंग प्रोग्राम और प्रक्रिया पहचानकर्ताओं के बीच संबंध स्थापित करता है और इसे औपचारिक पैरामीटर भी कहा जाता है। प्रक्रियाओं में तर्कों के लिए नियम समान हैं जो कार्यों के लिए हैं।

  • Local declarations - स्थानीय घोषणाएं लेबल, स्थिरांक, चर, कार्य और प्रक्रियाओं के लिए घोषणाओं को संदर्भित करती हैं, जो केवल प्रक्रिया के निकाय पर लागू होती हैं।

  • Procedure Body- प्रक्रिया निकाय में कथनों का एक संग्रह होता है जो परिभाषित करता है कि प्रक्रिया क्या करती है। इसे हमेशा आरक्षित शब्दों के बीच शुरू और अंत में संलग्न किया जाना चाहिए। यह एक प्रक्रिया का हिस्सा है जहां सभी संगणनाएँ की जाती हैं।

निम्नलिखित प्रक्रिया के लिए स्रोत कोड है, जिसे findMin () कहा जाता है । यह प्रक्रिया 4 पैरामीटर्स x, y, z और m लेती है और m नाम वाले वैरिएबल में पहले तीन वेरिएबल्स में न्यूनतम स्टोर करती है। चर एम द्वारा पारित किया गया हैreference (हम थोड़ी देर के संदर्भ में तर्क पारित करने पर चर्चा करेंगे) -

procedure findMin(x, y, z: integer; var m: integer); 
(* Finds the minimum of the 3 values *)

begin
   if x < y then
      m := x
   else
      m := y;
   
   if z <m then
      m := z;
end; { end of procedure findMin }

प्रक्रिया घोषणाएँ

एक प्रक्रिया declarationकंपाइलर को प्रक्रिया नाम और प्रक्रिया को कॉल करने के तरीके के बारे में बताता है। प्रक्रिया के वास्तविक शरीर को अलग से परिभाषित किया जा सकता है।

एक प्रक्रिया घोषणा में निम्नलिखित सिंटैक्स होता है -

procedure name(argument(s): type1, argument(s): type 2, ... );

कृपया ध्यान दें कि name of the procedure is not associated with any type। उपरोक्त परिभाषित प्रक्रिया के लिए findMin () , निम्नलिखित घोषणा है -

procedure findMin(x, y, z: integer; var m: integer);

एक प्रक्रिया कॉलिंग

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

एक प्रक्रिया को कॉल करने के लिए, आपको बस आवश्यक पैरामीटर पास करने की आवश्यकता है प्रक्रिया नाम के साथ नीचे दिखाया गया है -

program exProcedure;
var
   a, b, c,  min: integer;
procedure findMin(x, y, z: integer; var m: integer); 
(* Finds the minimum of the 3 values *)

begin
   if x < y then
      m:= x
   else
      m:= y;
   
   if z < m then
      m:= z;
end; { end of procedure findMin }  

begin
   writeln(' Enter three numbers: ');
   readln( a, b, c);
   findMin(a, b, c, min); (* Procedure call *)
   
   writeln(' Minimum: ', min);
end.

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

Enter three numbers:
89 45 67
Minimum: 45

पुनरावर्ती सबप्रोग्राम्स

हमने देखा है कि एक प्रोग्राम या सबप्रोग्राम दूसरे सबप्रोग्राम कह सकता है। जब कोई उपप्रोग्राम स्वयं कॉल करता है, तो उसे पुनरावर्ती कॉल के रूप में संदर्भित किया जाता है और इस प्रक्रिया को पुनरावर्ती के रूप में जाना जाता है।

अवधारणा को स्पष्ट करने के लिए, आइए एक संख्या के भाज्य की गणना करें। संख्या n के गुणन को इस प्रकार परिभाषित किया गया है -

n! = n*(n-1)!
   = n*(n-1)*(n-2)!
      ...
   = n*(n-1)*(n-2)*(n-3)... 1

निम्नलिखित कार्यक्रम खुद को पुनरावर्ती कहकर किसी दिए गए संख्या के भाज्य की गणना करता है।

program exRecursion;
var
   num, f: integer;
function fact(x: integer): integer; (* calculates factorial of x - x! *)

begin
   if x=0 then
      fact := 1
   else
      fact := x * fact(x-1); (* recursive call *)
end; { end of function fact}

begin
   writeln(' Enter a number: ');
   readln(num);
   f := fact(num);
   
   writeln(' Factorial ', num, ' is: ' , f);
end.

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

Enter a number:
5
Factorial 5 is: 120

निम्नलिखित एक और उदाहरण है, जो उत्पन्न करता है Fibonacci Series किसी दिए गए नंबर का उपयोग कर के लिए recursive कार्य -

program recursiveFibonacci;
var
   i: integer;
function fibonacci(n: integer): integer;

begin
   if n=1 then
      fibonacci := 0
   
   else if n=2 then
      fibonacci := 1
   
   else
      fibonacci := fibonacci(n-1) + fibonacci(n-2);
end; 

begin
   for i:= 1 to 10 do
   
   write(fibonacci (i), '  ');
end.

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

0 1 1 2	3 5 8 13 21 34

एक उपप्रकार के तर्क

यदि एक उपप्रोग्राम (function or procedure) तर्कों का उपयोग करना है, इसे चर घोषित करना चाहिए जो तर्कों के मूल्यों को स्वीकार करता है। इन चर को कहा जाता हैformal parameters उपप्रोग्राम का।

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

सबप्रोग्राम को कॉल करते समय, दो तरीके हैं जो तर्क को सबप्रोग्राम में पारित किया जा सकता है -

अनु क्रमांक कॉल प्रकार और विवरण
1 मूल्य से बुलाओ

यह विधि किसी तर्क के वास्तविक मान को उपप्रोग्राम के औपचारिक पैरामीटर में कॉपी करती है। इस स्थिति में, उपप्रोग्राम के अंदर पैरामीटर में किए गए परिवर्तनों का तर्क पर कोई प्रभाव नहीं पड़ता है।

2 संदर्भ से कॉल करें

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

डिफ़ॉल्ट रूप से, पास्कल का उपयोग करता है call by valueतर्क पारित करने के लिए। सामान्य तौर पर, इसका अर्थ है कि उपप्रोग्राम के भीतर का कोड उपप्रोग्राम को कॉल करने के लिए उपयोग किए गए तर्कों को बदल नहीं सकता है। उदाहरण कार्यक्रम जिसका उपयोग हमने अध्याय 'पास्कल - फंक्शन्स' में किया है, जिसे फंक्शन नाम दिया गया है जिसे मैक्स () का उपयोग किया जाता हैcall by value

जबकि, यहां दिया गया उदाहरण कार्यक्रम ( एक्सप्रोचर ) प्रक्रिया का उपयोग करके कॉल करता है findMin ()call by reference

किसी भी प्रोग्रामिंग में एक गुंजाइश कार्यक्रम का एक क्षेत्र है जहां एक परिभाषित चर का अस्तित्व हो सकता है और उस चर से परे तक पहुँचा नहीं जा सकता है। तीन जगह हैं, जहां पास्कल प्रोग्रामिंग भाषा में चर घोषित किए जा सकते हैं -

  • एक सबप्रोग्राम या एक ब्लॉक के अंदर जिसे स्थानीय चर कहा जाता है

  • सभी उपप्रोग्राम के बाहर जिसे वैश्विक चर कहा जाता है

  • उपप्रोग्राम मापदंडों की परिभाषा में जिसे औपचारिक पैरामीटर कहा जाता है

आइए हम बताते हैं कि क्या हैं local तथा global चर और औपचारिक पैरामीटर।

स्थानीय चर

वेरीबैल जिन्हें एक उपप्रोग्राम या ब्लॉक के अंदर घोषित किया जाता है, स्थानीय चर कहलाते हैं। उनका उपयोग केवल उन कथनों द्वारा किया जा सकता है जो उस सबप्रोग्राम या कोड के ब्लॉक के अंदर हैं। स्थानीय चर अपने स्वयं के बाहर उपप्रोग्राम के लिए ज्ञात नहीं हैं। निम्नलिखित स्थानीय चर का उपयोग करने वाला उदाहरण है। यहाँ, सभी चर , बी और सी एक्सलोकल नामक प्रोग्राम के लिए स्थानीय हैं ।

program exLocal; 
var
   a, b, c: integer;

begin
   (* actual initialization *)
   a := 10;
   b := 20;
   c := a + b;
   
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
end.

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

value of a = 10 b = 20 c = 30

अब, हम प्रोग्राम को थोड़ा और बढ़ाते हैं, आइए हम डिस्प्ले नामक एक प्रक्रिया बनाते हैं, जिसमें वेरिएबल , बी और सी का अपना सेट होगा और प्रोग्राम एक्सलोकल से सही, अपने मूल्यों को प्रदर्शित करेगा

program exLocal;
var
   a, b, c: integer;
procedure display;

var
   a, b, c: integer;
begin
   (* local variables *)
   a := 10;
   b := 20;
   c := a + b;
   
   writeln('Winthin the procedure display');
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
end;

begin
   a:= 100;
   b:= 200;
   c:= a + b;
   
   writeln('Winthin the program exlocal');
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
   display();
end.

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

Within the program exlocal
value of a = 100 b = 200 c = 300
Within the procedure display
value of a = 10 b = 20 c = 30

सार्वत्रिक चर

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

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

program exGlobal;
var
   a, b, c: integer;
procedure display;
var
   x, y, z: integer;

begin
   (* local variables *)
   x := 10;
   y := 20;
   z := x + y;
   
   (*global variables *)
   a := 30;
   b:= 40;
   c:= a + b;
   
   writeln('Winthin the procedure display');
   writeln(' Displaying the global variables a, b, and c');
   
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
   writeln('Displaying the local variables x, y, and z');
   
   writeln('value of x = ', x , ' y =  ',  y, ' and z = ', z);
end;

begin
   a:= 100;
   b:= 200;
   c:= 300;
   
   writeln('Winthin the program exlocal');
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
   
   display();
end.

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

Within the program exlocal
value of a = 100 b = 200 c = 300
Within the procedure display
Displaying the global variables a, b, and c
value of a = 30 b = 40 c = 70
Displaying the local variables x, y, and z
value of x = 10 y = 20 z = 30

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

पिछले उदाहरण को थोड़ा बदल दें, अब प्रक्रिया प्रदर्शन के लिए स्थानीय चर में a , b , c - जैसे नाम हैं।

program exGlobal;
var
   a, b, c: integer;
procedure display;

var
   a, b, c: integer;

begin
   (* local variables *)
   a := 10;
   b := 20;
   c := a + b;
   
   writeln('Winthin the procedure display');
   writeln(' Displaying the global variables a, b, and c');
   
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
   writeln('Displaying the local variables a, b, and c');
   
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);
end;

begin
   a:= 100;
   b:= 200;
   c:= 300;
   
   writeln('Winthin the program exlocal');
   writeln('value of a = ', a , ' b =  ',  b, ' and c = ', c);   
   
   display();
end.

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

Within the program exlocal
value of a = 100 b = 200 c = 300
Within the procedure display
Displaying the global variables a, b, and c
value of a = 10 b = 20 c = 30
Displaying the local variables a, b, and c
value of a = 10 b = 20 c = 30

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

आप एक स्ट्रिंग को कई तरीकों से परिभाषित कर सकते हैं -

  • Character arrays - यह एक चरित्र स्ट्रिंग है जो एकल उद्धरणों में संलग्न शून्य या अधिक बाइट-आकार के पात्रों का एक क्रम है।

  • String variables - स्ट्रिंग प्रकार का चर, जैसा कि टर्बो पास्कल में परिभाषित किया गया है।

  • Short strings - आकार विनिर्देश के साथ स्ट्रिंग प्रकार का चर।

  • Null terminated strings - का चर pchar प्रकार।

  • AnsiStrings - अंकन वे तार होते हैं जिनकी कोई लंबाई सीमा नहीं होती है।

पास्कल केवल एक स्ट्रिंग ऑपरेटर, स्ट्रिंग संघनन ऑपरेटर (+) प्रदान करता है।

उदाहरण

निम्नलिखित कार्यक्रम पहले चार प्रकार के तार प्रिंट करता है। हम अगले उदाहरण में AnsiStrings का उपयोग करेंगे।

program exString;
var
   greetings: string;
   name: packed array [1..10] of char;
   organisation: string[10];
   message: pchar;

begin
   greetings := 'Hello ';
   message := 'Good Day!';
   
   writeln('Please Enter your Name');
   readln(name);
   
   writeln('Please Enter the name of your Organisation');
   readln(organisation);
   
   writeln(greetings, name, ' from ', organisation);
   writeln(message); 
end.

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

Please Enter your Name
John Smith
Please Enter the name of your Organisation
Infotech
Hello John Smith from Infotech

निम्नलिखित उदाहरण कुछ और कार्यों का उपयोग करता है, आइए देखें -

program exString;
uses sysutils;
var
   str1, str2, str3 : ansistring;
   str4: string;
   len: integer;

begin
   str1 := 'Hello ';
   str2 := 'There!';
   
   (* copy str1 into str3 *)
   str3 := str1;
   writeln('appendstr( str3, str1) :  ', str3 );
   
   (* concatenates str1 and str2 *)
   appendstr( str1, str2);
   writeln( 'appendstr( str1, str2) ' , str1 );
   str4 := str1 + str2;
   writeln('Now str4 is: ', str4);
   
   (* total lenghth of str4 after concatenation  *)
   len := byte(str4[0]);
   writeln('Length of the final string str4: ', len); 
end.

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

appendstr( str3, str1) : Hello
appendstr( str1, str2) : Hello There!
Now str4 is: Hello There! There!
Length of the final string str4: 18

पास्कल स्ट्रिंग फ़ंक्शंस और प्रक्रियाएं

पास्कल कार्यों और प्रक्रियाओं की एक विस्तृत श्रृंखला का समर्थन करता है जो तारों में हेरफेर करते हैं। ये उपप्रोग्राम कार्यान्वयन-वार भिन्न होते हैं। यहां, हम फ्री पास्कल द्वारा प्रदान किए गए विभिन्न स्ट्रिंग हेरफेर उपप्रोग्राम सूचीबद्ध कर रहे हैं -

अनु क्रमांक। कार्य और उद्देश्य
1

function AnsiCompareStr(const S1: ; const S2:):Integer;

दो तारों की तुलना करता है

2

function AnsiCompareText(const S1: ; const S2:):Integer;

दो तारों की तुलना करता है, केस असंवेदनशील है

3

function AnsiExtractQuotedStr(var Src: PChar; Quote: Char):;

स्ट्रिंग से उद्धरण निकालता है

4

function AnsiLastChar(const S:):PChar;

स्ट्रिंग के अंतिम चरित्र हो जाता है

5

function AnsiLowerCase(const s:):

स्ट्रिंग को सभी-लोअरकेस में परिवर्तित करता है

6

function AnsiQuotedStr(const S: ; Quote: Char):;

एक उद्धरण उद्धृत करता है

7

function AnsiStrComp(S1: PChar;S2: PChar):Integer;

केस-संवेदी तार की तुलना करता है

8

function AnsiStrIComp(S1: PChar; S2: PChar):Integer;

तार केस-असंवेदनशील की तुलना करता है

9

function AnsiStrLComp(S1: PChar; S2: PChar; MaxLen: Cardinal):Integer;

संवेदनशील मामलों के एल वर्णों की तुलना करता है

10

function AnsiStrLIComp(S1: PChar; S2: PChar; MaxLen: Cardinal):Integer;

तुलना के एल वर्णों के मामले असंवेदनशील होते हैं

1 1

function AnsiStrLastChar(Str: PChar):PChar;

स्ट्रिंग के अंतिम चरित्र हो जाता है

12

function AnsiStrLower(Str: PChar):PChar;

स्ट्रिंग को सभी-लोअरकेस में परिवर्तित करता है

13

function AnsiStrUpper(Str: PChar):PChar;

स्ट्रिंग को सभी-अपरकेस में परिवर्तित करता है

14

function AnsiUpperCase(const s:):;

स्ट्रिंग को सभी-अपरकेस में परिवर्तित करता है

15

procedure AppendStr(var Dest: ; const S:);

2 तार लगाता है

16

procedure AssignStr(var P: PString; const S:);

ढेर पर स्ट्रिंग्स का मान असाइन करता है

17

function CompareStr(const S1: ; const S2:):Integer; overload;

दो स्ट्रिंग्स केस संवेदनशील की तुलना करता है

18

function CompareText(const S1: ; const S2:):Integer;

दो तार के मामले असंवेदनशील की तुलना करता है

19 procedure DisposeStr(S: PString); overload;

ढेर से स्ट्रिंग निकालता है

20

procedure DisposeStr(S: PShortString); overload;

ढेर से स्ट्रिंग निकालता है

21

function IsValidIdent( const Ident:):Boolean;

स्ट्रिंग एक मान्य पास्कल पहचानकर्ता है

22

function LastDelimiter(const Delimiters: ; const S:):Integer;

एक स्ट्रिंग में चरित्र की अंतिम घटना

23

function LeftStr(const S: ; Count: Integer):;

एक स्ट्रिंग के पहले N अक्षर मिलते हैं

24

function LoadStr(Ident: Integer):;

संसाधनों से भार स्ट्रिंग

25

function LowerCase(const s: ):; overload;

स्ट्रिंग को सभी-लोअरकेस में परिवर्तित करता है

26

function LowerCase(const V: variant ):; overload;

स्ट्रिंग को सभी-लोअरकेस में परिवर्तित करता है

27

function NewStr(const S:):PString; overload;

ढेर पर नए तार आवंटित करता है

28

function RightStr(const S: ; Count: Integer):;

एक स्ट्रिंग के अंतिम N अक्षर मिलते हैं

29

function StrAlloc(Size: Cardinal):PChar;

स्ट्रिंग के लिए मेमोरी आवंटित करता है

30

function StrBufSize(Str: PChar):SizeUInt;

एक स्ट्रिंग के लिए मेमोरी को सुरक्षित रखता है

31

procedure StrDispose(Str: PChar);

ढेर से स्ट्रिंग निकालता है

32

function StrPas(Str: PChar):;

PChar को पास्कल स्ट्रिंग में परिवर्तित करता है

33

function StrPCopy(Dest: PChar; Source:):PChar;

प्रतियां पास्कल स्ट्रिंग

34

function StrPLCopy(Dest: PChar; Source: ; MaxLen: SizeUInt):PChar;

पास्कल स्ट्रिंग की प्रतियां बाइट्स एन

35

function UpperCase(const s:):;

स्ट्रिंग को सभी-अपरकेस में परिवर्तित करता है

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

बूलियन मान मूल रूप से पूर्णांक प्रकार हैं। बूलियन प्रकार के चर में दो पूर्व-निर्धारित संभावित मूल्य होते हैंTrue तथा False। एक बूलियन मूल्य को हल करने वाले भाव भी एक बूलियन प्रकार को सौंपा जा सकता है।

फ्री पास्कल भी समर्थन करता है ByteBool, WordBool तथा LongBoolप्रकार के। ये क्रमशः बाइट, वर्ड या लॉन्गिंट प्रकार के होते हैं।

मूल्य मान 0 (शून्य) के बराबर होता है और बूलियन मान में परिवर्तित होने पर किसी भी गैर-मूल्य का मान सत्य माना जाता है। ट्रू का एक बूलियन मान -1 में परिवर्तित हो जाता है, जब इसे टाइप लॉन्गबुल के एक वेरिएबल को सौंपा जाता है।

यह ध्यान दिया जाना चाहिए कि तार्किक ऑपरेटर and, or तथा not बूलियन डेटा प्रकारों के लिए परिभाषित किया गया है।

बुलियन डेटा प्रकारों की घोषणा

बूलियन प्रकार का एक वैरिएबल का उपयोग किया जाता है।

var
boolean-identifier: boolean;

उदाहरण के लिए,

var
choice: boolean;

उदाहरण

program exBoolean;
var
exit: boolean;

choice: char;
   begin
   writeln('Do you want to continue? ');
   writeln('Enter Y/y for yes, and N/n for no');
   readln(choice);

if(choice = 'n') then
   exit := true
else
   exit := false;

if (exit) then
   writeln(' Good Bye!')
else
   writeln('Please Continue');

readln;
end.

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

Do you want to continue?
Enter Y/y for yes, and N/n for no
N
Good Bye!
Y
Please Continue

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

नंबर 1, नंबर 2, ... और नंबर 100 जैसे अलग-अलग चर घोषित करने के बजाय, आप एक सरणी चर जैसे संख्याओं की घोषणा करते हैं और संख्याओं का उपयोग करते हैं [1], संख्याओं [2] और ..., संख्याओं [100] का प्रतिनिधित्व करने के लिए अलग-अलग चर। एक सरणी में एक विशिष्ट तत्व एक सूचकांक द्वारा पहुँचा जाता है।

सभी सरणियों में सन्निहित स्मृति स्थान शामिल हैं। निम्नतम पता पहले तत्व से मेल खाता है और उच्चतम पता अंतिम तत्व से।

कृपया ध्यान दें कि यदि आप इंडेक्स 0 से शुरू होने वाली सी स्टाइल एरे चाहते हैं, तो आपको केवल 1 के बजाय 0 से इंडेक्स शुरू करने की आवश्यकता है।

घोषणाएँ

पास्कल में एक सरणी घोषित करने के लिए, एक प्रोग्रामर या तो प्रकार की घोषणा कर सकता है और फिर उस सरणी के चर बना सकता है या सीधे सरणी चर घोषित कर सकता है।

एक आयामी सरणी के प्रकार की घोषणा का सामान्य रूप है -

type
   array-identifier = array[index-type] of element-type;

कहाँ पे,

  • array-identifier - सरणी प्रकार का नाम इंगित करता है।

  • index-type- सरणी की सबस्क्रिप्ट निर्दिष्ट करता है; यह वास्तविक को छोड़कर किसी भी स्केलर डेटा प्रकार का हो सकता है

  • element-type - उन मूल्यों के प्रकारों को निर्दिष्ट करता है जो संग्रहीत होने जा रहे हैं

उदाहरण के लिए,

type
   vector = array [ 1..25] of real;
var
   velocity: vector;

अब, वेग वेक्टर प्रकार का एक परिवर्तनशील सरणी है, जो 25 वास्तविक संख्याओं को धारण करने के लिए पर्याप्त है।

ऐरे को 0 इंडेक्स से शुरू करने के लिए, घोषणा होगी -

type
   vector = array [ 0..24] of real;
var
   velocity: vector;

सरणी सदस्यता के प्रकार

पास्कल में, एक सरणी सबस्क्रिप्ट किसी भी स्केलर प्रकार की हो सकती है, जैसे कि पूर्णांक, बूलियन, एनुमरेटेड या सबरेंज, वास्तविक को छोड़कर। सरणी सदस्यता नकारात्मक मान भी हो सकती है।

उदाहरण के लिए,

type
   temperature = array [-10 .. 50] of real;
var
   day_temp, night_temp: temperature;

आइए एक और उदाहरण लेते हैं जहां सबस्क्रिप्ट चरित्र प्रकार का है -

type
   ch_array = array[char] of 1..26;
var
   alphabet: ch_array;

सदस्यता एन्यूमरेटेड प्रकार की हो सकती है -

type
   color = ( red, black, blue, silver, beige);
   car_color = array of [color] of boolean;
var
   car_body: car_color;

आरंभिक सारणी

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

उदाहरण के लिए -

type
   ch_array = array[char] of 1..26;
var
   alphabet: ch_array;
   c: char;

begin
   ...
   for c:= 'A' to 'Z' do
   alphabet[c] := ord[m];  
   (* the ord() function returns the ordinal values *)

ऐरे तत्वों तक पहुँचना

सरणी नाम को अनुक्रमित करके एक तत्व को एक्सेस किया जाता है। यह सरणी के नाम के बाद वर्ग ब्रैकेट के भीतर तत्व के सूचकांक को रखकर किया जाता है। उदाहरण के लिए -

a: integer;
a: = alphabet['A'];

उपरोक्त कथन वर्णमाला नाम के ऐरे से पहला तत्व लेगा और वैरिएबल के मान को असाइन करेगा।

निम्नलिखित एक उदाहरण है, जो उपरोक्त सभी तीन अवधारणाओं का उपयोग करेगा। घोषणा, असाइनमेंट और पहुँच सरणियाँ -

program exArrays;
var
   n: array [1..10] of integer;   (* n is an array of 10 integers *)
   i, j: integer;

begin
   (* initialize elements of array n to 0 *)        
   for i := 1 to 10 do
       n[ i ] := i + 100;   (* set element at location i to i + 100 *)
    (* output each array element's value *)
   
   for j:= 1 to 10 do
      writeln('Element[', j, '] = ', n[j] );
end.

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

Element[1] = 101
Element[2] = 102
Element[3] = 103
Element[4] = 104
Element[5] = 105
Element[6] = 106
Element[7] = 107
Element[8] = 108
Element[9] = 109
Element[10] = 110

पास्कल एर्सेस डिटेल में

Arrays पास्कल के लिए महत्वपूर्ण हैं और अधिक विवरणों की बहुत आवश्यकता होनी चाहिए। सरणी से संबंधित कुछ महत्वपूर्ण अवधारणाएँ निम्नलिखित हैं जो पास्कल प्रोग्रामर के लिए स्पष्ट होनी चाहिए -

अनु क्रमांक अवधारणा और विवरण
1 बहुआयामी सरणियाँ

पास्कल बहुआयामी सरणियों का समर्थन करता है। बहुआयामी सरणी का सबसे सरल रूप द्वि-आयामी सरणी है।

2 गतिशील सरणी

इस प्रकार के सरणियों में, प्रारंभिक लंबाई शून्य है। सरणी की वास्तविक लंबाई मानक के साथ निर्धारित की जानी चाहिएSetLength समारोह।

3 पैक की गई सरणी

ये सरणियाँ बिट-पैक हैं, अर्थात, प्रत्येक वर्ण या सत्य मान एक भंडारण इकाई का उपयोग करने के बजाय लगातार बाइट्स में संग्रहीत किया जाता है, आमतौर पर एक शब्द (4 बाइट्स या अधिक)।

4 उपप्रोग्राम में सरणियाँ गुजरना

आप किसी अनुक्रमणिका के बिना सरणी का नाम निर्दिष्ट करके किसी सरणी में उपप्रोग्राम सूचक को पास कर सकते हैं।

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

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

पॉइंटर्स क्या हैं?

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

type
   ptr-identifier = ^base-variable-type;

सूचक प्रकार को आधार प्रकार के साथ कैरेट प्रतीक (^) के ऊपर-तीर को ऊपर करके परिभाषित किया गया है। आधार-प्रकार डेटा आइटम के प्रकार को परिभाषित करता है। एक बार एक पॉइंटर वैरिएबल को कुछ प्रकार के रूप में परिभाषित किया गया है, यह केवल उस प्रकार के डेटा आइटम को इंगित कर सकता है। एक बार एक पॉइंटर प्रकार परिभाषित किया गया है, हम इसका उपयोग कर सकते हैंvar सूचक चर घोषित करने के लिए घोषणा।

var
   p1, p2, ... : ptr-identifier;

कुछ मान्य सूचक घोषणाएँ निम्नलिखित हैं -

type
   Rptr = ^real;
   Cptr = ^char;
   Bptr = ^ Boolean;
   Aptr = ^array[1..5] of real;
   date-ptr = ^ date;
      Date = record
         Day: 1..31;
         Month: 1..12;
         Year: 1900..3000;
      End;
var
   a, b : Rptr;
   d: date-ptr;

पॉइंटर चर समान कैरेट प्रतीक (^) का उपयोग करके dereferenced हैं। उदाहरण के लिए, एक सूचक rptr द्वारा संदर्भित संबंधित चर , rptr ^ है । इसे इस रूप में देखा जा सकता है -

rptr^ := 234.56;

निम्नलिखित उदाहरण इस अवधारणा को चित्रित करेगा -

program exPointers;
var
   number: integer;
   iptr: ^integer;

begin
   number := 100;
   writeln('Number is: ', number);
   
   iptr := @number;
   writeln('iptr points to a value: ', iptr^);
   
   iptr^ := 200;
   writeln('Number is: ', number);
   writeln('iptr points to a value: ', iptr^);
end.

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

Number is: 100
iptr points to a value: 100
Number is: 200
iptr points to a value: 200

पास्कल में मेमोरी एड्रेस प्रिंट करना

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

हमें पॉइंटर IPtr में संग्रहीत मेमोरी एड्रेस को प्रिंट करने के लिए उपरोक्त उदाहरण का विस्तार करें -

program exPointers;
var
   number: integer;
   iptr: ^integer;
   y: ^word;

begin
   number := 100;
   writeln('Number is: ', number);
   iptr := @number;
   writeln('iptr points to a value: ', iptr^);
   
   iptr^ := 200;
   writeln('Number is: ', number);
   writeln('iptr points to a value: ', iptr^);
   y := addr(iptr);
   writeln(y^); 
end.

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

Number is: 100
iptr points to a value: 100
Number is: 200
iptr points to a value: 200
45504

NIL के संकेत

यह हमेशा एक अच्छा काम है NILआपके पास असाइन किए जाने के लिए सटीक पता नहीं होने की स्थिति में एक पॉइंटर चर का मान। यह चर घोषणा के समय किया जाता है। एक सूचक जो सौंपा गया हैNILकहीं नहीं। निम्नलिखित कार्यक्रम पर विचार करें -

program exPointers;
var
   number: integer;
   iptr: ^integer;
   y: ^word;

begin
   iptr := nil;
   y := addr(iptr);
   
   writeln('the vaule of iptr is ', y^);
end.

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

The value of ptr is 0

के लिए जाँच करने के लिए nil पॉइंटर आप एक निम्न कथन का उपयोग कर सकते हैं -

if(ptr <> nill )then     (* succeeds if p is not null *)
if(ptr = nill)then    (* succeeds if p is null *)

पास्कल पॉइंटर्स विस्तार से

पॉइंटर्स के पास कई लेकिन आसान अवधारणाएं हैं और वे पास्कल प्रोग्रामिंग के लिए बहुत महत्वपूर्ण हैं। कुछ महत्वपूर्ण सूचक अवधारणाएँ निम्नलिखित हैं, जो पास्कल प्रोग्रामर के लिए स्पष्ट होनी चाहिए -

अनु क्रमांक अवधारणा और विवरण
1 पास्कल - सूचक अंकगणित

चार अंकगणितीय ऑपरेटर हैं जिनका उपयोग बिंदुओं पर किया जा सकता है: वेतन वृद्धि, वेतन वृद्धि, + - -

2 पास्कल - संकेत की सरणी

आप कई बिंदुओं को रखने के लिए सरणियों को परिभाषित कर सकते हैं।

3 पास्कल - सूचक को इंगित करता है

पास्कल आपको सूचक और इतने पर सूचक रखने की अनुमति देता है।

4 पास्कल में सबप्रोग्राम करने के लिए पासिंग पॉइंट्स

एक तर्क को संदर्भ या पते से पास करना, दोनों पारित तर्क को कॉलिंग सबप्रोग्राम में परिवर्तित करने में सक्षम बनाता है, जिसे उपप्रोग्राम कहा जाता है।

5 पास्कल में उपप्रोग्राम से सूचक लौटें

पास्कल एक सबप्रोग्राम को पॉइंटर वापस करने की अनुमति देता है।

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

रिकॉर्ड में अलग-अलग क्षेत्र शामिल हैं। मान लीजिए कि आप अपनी पुस्तकों का विवरण किसी पुस्तकालय में रखना चाहते हैं, तो आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाह सकते हैं -

  • Title
  • Author
  • Subject
  • बुक आईडी

एक रिकॉर्ड को परिभाषित करना

एक रिकॉर्ड प्रकार को परिभाषित करने के लिए, आप टाइप डिक्लेरेशन स्टेटमेंट का उपयोग कर सकते हैं। रिकॉर्ड प्रकार को इस प्रकार परिभाषित किया गया है -

type
record-name = record
   field-1: field-type1;
   field-2: field-type2;
   ...
   field-n: field-typen;
end;

इस तरह से आप बुक रिकॉर्ड घोषित करेंगे -

type 
Books = record
   title: packed array [1..50] of char;
   author: packed array [1..50] of char;
   subject: packed array [1..100] of char;
   book_id: integer;
end;

रिकॉर्ड चर को सामान्य तरीके से परिभाषित किया गया है

var
   r1, r2, ... : record-name;

वैकल्पिक रूप से, आप सीधे एक रिकॉर्ड प्रकार चर को परिभाषित कर सकते हैं -

var
Books : record
   title: packed array [1..50] of char;
   author: packed array [1..50] of char;
   subject: packed array [1..100] of char;
   book_id: integer;
end;

एक रिकॉर्ड के क्षेत्रों तक पहुँचने

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

program exRecords;
type
Books = record
   title: packed array [1..50] of char;
   author: packed array [1..50] of char;
   subject: packed array [1..100] of char;
   book_id: longint;
end;

var
   Book1, Book2: Books; (* Declare Book1 and Book2 of type Books *)

begin
   (* book 1 specification *)
   Book1.title  := 'C Programming';
   Book1.author := 'Nuha Ali '; 
   Book1.subject := 'C Programming Tutorial';
   Book1.book_id := 6495407;

   (* book 2 specification *)
   Book2.title := 'Telecom Billing';
   Book2.author := 'Zara Ali';
   Book2.subject := 'Telecom Billing Tutorial';
   Book2.book_id := 6495700;
 
   (* print Book1 info *)
   writeln ('Book 1 title : ', Book1.title);
   writeln('Book 1 author : ', Book1.author);
   writeln( 'Book 1 subject : ', Book1.subject);
   writeln( 'Book 1 book_id : ', Book1.book_id);
   writeln; 

   (* print Book2 info *)
   writeln ('Book 2 title : ', Book2.title);
   writeln('Book 2 author : ', Book2.author);
   writeln( 'Book 2 subject : ', Book2.subject);
   writeln( 'Book 2 book_id : ', Book2.book_id);
end.

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

Book 1 title : C Programming
Book 1 author : Nuha Ali
Book 1 subject : C Programming Tutorial
Book 1 book_id : 6495407

Book 2 title : Telecom Billing
Book 2 author : Zara Ali
Book 2 subject : Telecom Billing Tutorial
Book 2 book_id : 6495700

सबप्रोग्राम तर्क के रूप में रिकॉर्ड

आप एक रिकॉर्ड को उपप्रोग्राम तर्क के रूप में उसी तरह से पारित कर सकते हैं जैसे आप किसी अन्य चर या सूचक को पास करते हैं। आप रिकॉर्ड फ़ील्ड को उसी तरह एक्सेस करेंगे जैसे आपने उपरोक्त उदाहरण में एक्सेस किया है -

program exRecords;
type
Books = record
   title: packed array [1..50] of char;
   author: packed array [1..50] of char;
   subject: packed array [1..100] of char;
   book_id: longint;
end;

var
   Book1, Book2: Books; (* Declare Book1 and Book2 of type Books *)

(* procedure declaration *)
procedure printBook( var book: Books );

begin
   (* print Book info *)
   writeln ('Book  title : ', book.title);
   writeln('Book  author : ', book.author);
   writeln( 'Book  subject : ', book.subject);
   writeln( 'Book book_id : ', book.book_id);
end;

begin
   (* book 1 specification *)
   Book1.title  := 'C Programming';
   Book1.author := 'Nuha Ali '; 
   Book1.subject := 'C Programming Tutorial';
   Book1.book_id := 6495407;
   
   (* book 2 specification *)
   Book2.title := 'Telecom Billing';
   Book2.author := 'Zara Ali';
   Book2.subject := 'Telecom Billing Tutorial';
   Book2.book_id := 6495700;
   
   (* print Book1 info *)
   printbook(Book1);
   writeln; 

   (* print Book2 info *)
   printbook(Book2);
end.

When the above code is compiled and executed, it produces the following result −

Book 1 title : C Programming
Book 1 author : Nuha Ali
Book 1 subject : C Programming Tutorial
Book 1 book_id : 6495407

Book 2 title : Telecom Billing
Book 2 author : Zara Ali
Book 2 subject : Telecom Billing Tutorial
Book 2 book_id : 6495700

Pointers to Records

You can define pointers to records in very similar way as you define pointer to any other variable as follows −

type
record-ptr = ^ record-name;
record-name = record
   field-1: field-type1;
   field-2: field-type2;
   ...
   field-n: field-typen;
end;

Now, you can store the address of a record type variable in the above-defined pointer variable. To declare a variable of the created pointer type, you use the var keyword −

var
   r1, r2, ... : record-ptr;

Before using these pointers, you must create storage for a record-name type variable, which will be manipulated by these pointers.

new(r1);
new(r2);

To access the members of a record using a pointer to that record, you must use the ^. operator as follows −

r1^.feild1 := value1;
r1^.feild2 := value2;
...
r1^fieldn := valuen;

Finally, don't forget to dispose the used storage, when it is no longer in use −

dispose(r1);
dispose(r2);

Let us re-write the first example using a pointer to the Books record. Hope this will be easy for you to understand the concept −

program exRecords;
type
BooksPtr = ^ Books;
Books = record
   title: packed array [1..50] of char;
   author: packed array [1..50] of char;
   subject: packed array [1..100] of char;
   book_id: longint;
end;

var
  (* Declare Book1 and Book2 of pointer type that refers to Book type *)
   Book1, Book2: BooksPtr; 

begin
   new(Book1);
   new(book2);
   
   (* book 1 specification *)
   Book1^.title  := 'C Programming';
   Book1^.author := 'Nuha Ali '; 
   Book1^.subject := 'C Programming Tutorial';
   Book1^.book_id := 6495407;
   
   (* book 2 specification *)
   Book2^.title := 'Telecom Billing';
   Book2^.author := 'Zara Ali';
   Book2^.subject := 'Telecom Billing Tutorial';
   Book2^.book_id := 6495700;
   
   (* print Book1 info *)
   writeln ('Book 1 title : ', Book1^.title);
   writeln('Book 1 author : ', Book1^.author);
   writeln( 'Book 1 subject : ', Book1^.subject);
   writeln( 'Book 1 book_id : ', Book1^.book_id);
   
   (* print Book2 info *)
   writeln ('Book 2 title : ', Book2^.title);
   writeln('Book 2 author : ', Book2^.author);
   writeln( 'Book 2 subject : ', Book2^.subject);
   writeln( 'Book 2 book_id : ', Book2^.book_id);
   
   dispose(Book1); 
   dispose(Book2);
end.

When the above code is compiled and executed, it produces the following result −

Book 1 title : C Programming
Book 1 author : Nuha Ali
Book 1 subject : C Programming Tutorial
Book 1 book_id : 6495407

Book 2 title : Telecom Billing
Book 2 author : Zara Ali
Book 2 subject : Telecom Billing Tutorial
Book 2 book_id : 6495700

The With Statement

We have discussed that the members of a record can be accessed using the member access operator (.). This way the name of the record variable has to be written every time. The With statement provides an alternative way to do that.

Look at the following code snippet taken from our first example −

(* book 1 specification *)
   Book1.title  := 'C Programming';
   Book1.author := 'Nuha Ali '; 
   Book1.subject := 'C Programming Tutorial';
   Book1.book_id := 6495407;

The same assignment could be written using the With statement as −

(* book 1 specification *)
With Book1 do
begin
   title  := 'C Programming';
   author := 'Nuha Ali '; 
   subject := 'C Programming Tutorial';
   book_id := 6495407;
end;

Pascal supports a unique type of storage named variants. You can assign any simple type of values in a variant variable. The type of a value stored in a variant is only determined at runtime. Almost any simple type can be assigned to variants: ordinal types, string types, int64 types.

Structured types such as sets, records, arrays, files, objects and classes are not assignment-compatible with a variant. You can also assign a pointer to a variant.

Free Pascal supports variants.

Declaring a Variant

You can declare variant type like any other types using the var keyword. The syntax for declaring a variant type is −

var
   v: variant;

Now, this variant variable v can be assigned to almost all simple types including the enumerated types and vice versa.

type  
   color = (red, black, white);  
var  
   v : variant;  
   i : integer;  
   b : byte;  
   w : word;  
   q : int64;  
   e : extended;  
   d : double;  
   en : color;  
   as : ansistring;  
   ws : widestring;  

begin  
   v := i;  
   v := b;  
   v := w;  
   v := q;  
   v := e;  
   v := en;  
   v := d:  
   v := as;  
   v := ws;  
end;

Example

The following example would illustrate the concept −

Program exVariant;

uses variants;
type
   color = (red, black, white);

var
   v : variant;
   i : integer;
   r: real;
   c : color;
   as : ansistring;


begin
   i := 100;
   v:= i;
   writeln('Variant as Integer: ', v);

   r:= 234.345;
   v:= r;
   writeln('Variant as real: ', v);

   c := red;
   v := c;
   writeln('Variant as Enumerated data: ', v);

   as:= ' I am an AnsiString';
   v:= as;
   writeln('Variant as AnsiString: ', v);
end.

When the above code is compiled and executed, it produces the following result −

Variant as Integer: 100
Variant as real: 234.345
Variant as Enumerated data: 0
Variant as AnsiString: I am an AnsiString

A set is a collection of elements of same type. Pascal allows defining the set data type. The elements in a set are called its members. In mathematics, sets are represented by enclosing the members within braces{}. However, in Pascal, set elements are enclosed within square brackets [], which are referred as set constructor.

Defining Set Types and Variables

Pascal Set types are defined as

type
set-identifier = set of base type;

Variables of set type are defined as

var
s1, s2, ...: set-identifier;

or,

s1, s2...: set of base type;

Examples of some valid set type declaration are −

type
Days = (mon, tue, wed, thu, fri, sat, sun);
Letters = set of char;
DaySet = set of days;
Alphabets = set of 'A' .. 'Z';
studentAge = set of 13..20;

Set Operators

You can perform the following set operations on Pascal sets.

Sr.No Operations & Descriptions
1

Union

This joins two sets and gives a new set with members from both sets.

2

Difference

Gets the difference of two sets and gives a new set with elements not common to either set.

3

Intersection

Gets the intersection of two sets and gives a new set with elements common to both sets.

4

Inclusion

A set P is included in set Q, if all items in P are also in Q but not vice versa.

5

Symmetric difference

Gets the symmetric difference of two sets and gives a set of elements, which are in either of the sets and not in their intersection.

6

In

It checks membership.

Following table shows all the set operators supported by Free Pascal. Assume that S1 and S2 are two character sets, such that −

S1 := ['a', 'b', 'c'];

S2 := ['c', 'd', 'e'];

Operator Description Example
+ Union of two sets

S1 + S2 will give a set

['a', 'b', 'c', 'd', 'e']

- Difference of two sets

S1 - S2 will give a set

['a', 'b']

* Intersection of two sets

S1 * S2 will give a set

['c']

>< Symmetric difference of two sets S1 >< S2 will give a set ['a', 'b', 'd', 'e']
= Checks equality of two sets S1 = S2 will give the boolean value False
<> Checks non-equality of two sets S1 <> S2 will give the boolean value True
<= Contains (Checks if one set is a subset of the other) S1 <= S2 will give the boolean value False
Include Includes an element in the set; basically it is the Union of a set and an element of same base type

Include (S1, ['d']) will give a set

['a', 'b', 'c', 'd']

Exclude Excludes an element from a set; basically it is the Difference of a set and an element of same base type

Exclude (S2, ['d']) will give a set

['c', 'e']

In Checks set membership of an element in a set ['e'] in S2 gives the boolean value True

Example

The following example illustrates the use of some of these operators −

program setColors;
type  
color = (red, blue, yellow, green, white, black, orange);  
colors = set of color;  
 
procedure displayColors(c : colors);  
const  
names : array [color] of String[7]  
  = ('red', 'blue', 'yellow', 'green', 'white', 'black', 'orange');  
var  
   cl : color;  
   s : String;  

begin  
   s:= ' ';  
   for cl:=red to orange do  
      if cl in c then  
      begin  
         if (s<>' ') then s :=s +' , ';  
         s:=s+names[cl];  
      end;  
   writeln('[',s,']');  
end;  
 
var  
   c : colors;  
 
begin  
   c:= [red, blue, yellow, green, white, black, orange];
   displayColors(c);

   c:=[red, blue]+[yellow, green]; 
   displayColors(c);  

   c:=[red, blue, yellow, green, white, black, orange] - [green, white];     
   displayColors(c);    

   c:= [red, blue, yellow, green, white, black, orange]*[green, white];     
   displayColors(c);  

   c:= [red, blue, yellow, green]><[yellow, green, white, black]; 
   displayColors(c);  
end.

When the above code is compiled and executed, it produces the following result −

[ red , blue , yellow , green , white , black , orange]
[ red , blue , yellow , green]
[ red , blue , yellow , black , orange]
[ green , white]
[ red , blue , white , black]

Pascal treats a file as a sequence of components, which must be of uniform type. A file's type is determined by the type of the components. File data type is defined as −

type
file-name = file of base-type;

Where, the base-type indicates the type of the components of the file. The base type could be anything like, integer, real, Boolean, enumerated, subrange, record, arrays and sets except another file type. Variables of a file type are created using the var declaration −

var
f1, f2,...: file-name;

कुछ फ़ाइल प्रकारों और फ़ाइल चर को परिभाषित करने के कुछ उदाहरण निम्नलिखित हैं -

type
   rfile = file of real;
   ifile = file of integer;
   bfile = file of boolean;
   datafile = file of record
   arrfile = file of array[1..4] of integer;

var
   marks: arrfile;
   studentdata: datafile;
   rainfalldata: rfile;
   tempdata: ifile;
   choices: bfile;

फ़ाइल बनाना और लिखना

आइए हम एक कार्यक्रम लिखें जो छात्रों के रिकॉर्ड के लिए एक डेटा फ़ाइल बनाएगा। यह छात्रों के नाम पर एक फ़ाइल बनाएगा। छात्र इसमें डेटा लिखेगा -

program DataFiles;
type
   StudentRecord = Record
      s_name: String;
      s_addr: String;
      s_batchcode: String;
   end;

var
   Student: StudentRecord;
   f: file of StudentRecord;

begin
   Assign(f,'students.dat');
   Rewrite(f);
   Student.s_name := 'John Smith';
   Student.s_addr := 'United States of America';
   Student.s_batchcode := 'Computer Science';
   Write(f,Student);
   Close(f);
end.

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

एक फ़ाइल से पढ़ना

हमने अभी छात्रों के नाम पर एक फ़ाइल बनाई और लिखी है। अब, हम एक प्रोग्राम लिखते हैं जो फ़ाइल से छात्र के डेटा को पढ़ेगा -

program DataFiles;
type
   StudentRecord = Record
      s_name: String;
      s_addr: String;
      s_batchcode: String;
   end;

var
   Student: StudentRecord;
   f: file of StudentRecord;

begin
   assign(f, 'students.dat');
   reset(f); 
   while not eof(f) do
   
   begin
      read(f,Student);
      writeln('Name: ',Student.s_name);
      writeln('Address: ',Student.s_addr);
      writeln('Batch Code: ', Student.s_batchcode);
   end;
   
   close(f);
end.

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

Name: John Smith
Address: United States of America
Batch Code: Computer Science

उपप्रोग्राम पैरामीटर के रूप में फ़ाइलें

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

कृपया ध्यान दें कि, if you use a file parameter with subprograms, it must be declared as a var parameter.

program addFiledata;
const
   MAX = 4;
type
   raindata = file of real;

var
   rainfile: raindata;
   filename: string;
procedure writedata(var f: raindata);

var
   data: real;
   i: integer;

begin
   rewrite(f, sizeof(data));
   for i:=1 to MAX do
   
   begin
      writeln('Enter rainfall data: ');
      readln(data);
      write(f, data);
   end;
   
   close(f);
end;

procedure computeAverage(var x: raindata);
var
   d, sum: real;
   average: real;

begin
   reset(x);
   sum:= 0.0;
   while not eof(x) do
   
   begin
      read(x, d);
      sum := sum + d;
   end;
   
   average := sum/MAX;
   close(x);
   writeln('Average Rainfall: ', average:7:2);
end;

begin
   writeln('Enter the File Name: ');
   readln(filename);
   assign(rainfile, filename);
   writedata(rainfile);
   computeAverage(rainfile);
end.

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

Enter the File Name:
rainfall.txt
Enter rainfall data:
34
Enter rainfall data:
45
Enter rainfall data:
56
Enter rainfall data:
78
Average Rainfall: 53.25

पाठ फ़ाइलें

पास्कल में एक टेक्स्ट फ़ाइल, वर्णों की पंक्तियों से युक्त होती है, जहाँ प्रत्येक पंक्ति को अंत-पंक्ति मार्कर के साथ समाप्त किया जाता है। आप ऐसी फ़ाइलों को घोषित और परिभाषित कर सकते हैं -

type
file-name = text;

वर्णों की एक सामान्य फ़ाइल और एक पाठ फ़ाइल के बीच अंतर यह है कि एक पाठ फ़ाइल को लाइनों में विभाजित किया जाता है, प्रत्येक को एक विशेष एंड-ऑफ-लाइन मार्कर द्वारा समाप्त किया जाता है, स्वचालित रूप से सिस्टम द्वारा डाला जाता है। निम्नलिखित उदाहरण contact.txt नामक एक पाठ फ़ाइल में बनाता है और लिखता है -

program exText;
var
   filename, data: string;
   myfile: text;

begin
   writeln('Enter the file name: ');
   readln(filename);
   
   assign(myfile, filename);
   rewrite(myfile);
   
   writeln(myfile, 'Note to Students: ');
   writeln(myfile, 'For details information on Pascal Programming');
   writeln(myfile, 'Contact: Tutorials Point');
   writeln('Completed writing'); 
   
   close(myfile);
end.

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

Enter the file name:
contact.txt 
Completed writing

फ़ाइल में लागू करना

फ़ाइल में लागू होने का मतलब मौजूदा फ़ाइल में लिखना है जिसमें पहले से ही फ़ाइल को अधिलेखित किए बिना कुछ डेटा है। निम्नलिखित कार्यक्रम यह दिखाता है -

program exAppendfile;
var
   myfile: text;
   info: string;

begin
   assign(myfile, 'contact.txt');
   append(myfile);
   
   writeln('Contact Details');
   writeln('[email protected]');
   close(myfile);
   
   (* let us read from this file *)
   assign(myfile, 'contact.txt');
   reset(myfile);
   while not eof(myfile) do
   
   begin
      readln(myfile, info);
      writeln(info);
   end;
   close(myfile);
end.

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

Contact Details
[email protected]
Note to Students:
For details information on Pascal Programming
Contact: Tutorials Point

फ़ाइल हैंडलिंग कार्य

नि: शुल्क पास्कल फ़ाइल से निपटने के लिए निम्नलिखित कार्य / प्रक्रियाएं प्रदान करता है -

अनु क्रमांक। समारोह का नाम और विवरण
1

procedure Append(var t: Text);

एपेंड मोड में एक फाइल खोलता है

2

procedure Assign(out f: file; const Name:);

एक फ़ाइल के लिए एक नाम असाइन करता है

3

procedure Assign(out f: file; p: PChar);

एक फ़ाइल के लिए एक नाम असाइन करता है

4

procedure Assign(out f: file; c: Char);

एक फ़ाइल के लिए एक नाम असाइन करता है

5

procedure Assign(out f: TypedFile; const Name:);

एक फ़ाइल के लिए एक नाम असाइन करता है

6

procedure Assign(out f: TypedFile; p: PChar);

एक फ़ाइल के लिए एक नाम असाइन करता है

7

procedure Assign(out f: TypedFile; c: Char);

एक फ़ाइल के लिए एक नाम असाइन करता है

8

procedure Assign(out t: Text; const s:);

एक फ़ाइल के लिए एक नाम असाइन करता है

9

procedure Assign(out t: Text; p: PChar);

एक फ़ाइल के लिए एक नाम असाइन करता है

10

procedure Assign(out t: Text; c: Char);

एक फ़ाइल के लिए एक नाम असाइन करता है

1 1

procedure BlockRead(var f: file; var Buf; count: Int64; var Result: Int64);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

12

procedure BlockRead(var f: file; var Buf; count: LongInt; var Result: LongInt);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

13

procedure BlockRead(var f: file; var Buf; count: Cardinal; var Result: Cardinal);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

14

procedure BlockRead(var f: file; var Buf; count: Word; var Result: Word);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

15

procedure BlockRead(var f: file; var Buf; count: Word; var Result: Integer);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

16

procedure BlockRead(var f: file; var Buf; count: Int64);

एक फ़ाइल से डेटा को मेमोरी में पढ़ता है

17

procedure BlockWrite(var f: file; const Buf; Count: Int64; var Result: Int64);

मेमोरी से फाइल में डेटा लिखता है

18

procedure BlockWrite(var f: file; const Buf; Count: LongInt; var Result: LongInt);

मेमोरी से फाइल में डेटा लिखता है

19

procedure BlockWrite(var f: file; const Buf; Count: Cardinal; var Result: Cardinal);

मेमोरी से फाइल में डेटा लिखता है

20

procedure BlockWrite(var f: file; const Buf; Count: Word; var Result: Word);

मेमोरी से फाइल में डेटा लिखता है

21

procedure BlockWrite(var f: file; const Buf; Count: Word; var Result: Integer);

मेमोरी से फाइल में डेटा लिखता है

22

procedure BlockWrite(var f: file; const Buf; Count: LongInt);

मेमोरी से फाइल में डेटा लिखता है

23

procedure Close(var f: file);

एक फ़ाइल बंद करता है

24

procedure Close(var t: Text);

एक फ़ाइल बंद करता है

25

function EOF(var f: file):Boolean;

फ़ाइल के अंत के लिए जाँच करता है

26

function EOF(var t: Text):Boolean;

फ़ाइल के अंत के लिए जाँच करता है

27

function EOF: Boolean;

फ़ाइल के अंत के लिए जाँच करता है

28

function EOLn(var t: Text):Boolean;

लाइन के अंत के लिए जाँच करता है

29

function EOLn: Boolean;

लाइन के अंत के लिए जाँच करता है

30

procedure Erase(var f: file);

डिस्क से फ़ाइल हटाता है

31

procedure Erase(var t: Text);

डिस्क से फ़ाइल हटाता है

32

function FilePos( var f: file):Int64;

फ़ाइल में स्थिति

33

function FileSize(var f: file):Int64;

फ़ाइल का आकार

34

procedure Flush(var t: Text);

डिस्क पर फ़ाइल बफ़र लिखता है

35

function IOResult: Word;

अंतिम फ़ाइल आईओ ऑपरेशन के परिणाम देता है

36

procedure Read(var F: Text; Args: Arguments);

चर में फ़ाइल से पढ़ता है

37

procedure Read(Args: Arguments);

चर में फ़ाइल से पढ़ता है

38

procedure ReadLn(var F: Text; Args: Arguments);

चर और गोटो अगली पंक्ति में फ़ाइल से पढ़ता है

39

procedure ReadLn(Args: Arguments);

चर और गोटो अगली पंक्ति में फ़ाइल से पढ़ता है

40

procedure Rename(var f: file; const s:);

डिस्क पर फ़ाइल का नाम

41

procedure Rename(var f: file; p: PChar);

डिस्क पर फ़ाइल का नाम

42

procedure Rename(var f: file; c: Char);

डिस्क पर फ़ाइल का नाम

43

procedure Rename(var t: Text; const s);

डिस्क पर फ़ाइल का नाम बदलें

44

procedure Rename(var t: Text; p: PChar);

डिस्क पर फ़ाइल का नाम

45

procedure Rename( var t: Text; c: Char);

डिस्क पर फ़ाइल का नाम

46

procedure Reset(var f: file; l: LongInt);

पढ़ने के लिए फ़ाइल खोलता है

47

procedure Reset(var f: file);

पढ़ने के लिए फ़ाइल खोलता है

48

procedure Reset(var f: TypedFile);

पढ़ने के लिए फ़ाइल खोलता है

49

procedure Reset(var t: Text);

पढ़ने के लिए फ़ाइल खोलता है

50

procedure Rewrite(var f: file; l: LongInt);

लिखने के लिए फाइल खोलता है

51

procedure Rewrite(var f: file);

लिखने के लिए फाइल खोलता है

52

procedure Rewrite(var f: TypedFile);

लिखने के लिए फाइल खोलता है

53

procedure Rewrite(var t: Text);

लिखने के लिए फाइल खोलता है

54

procedure Seek(var f: file; Pos: Int64);

फ़ाइल स्थिति सेट करता है

55

function SeekEOF(var t: Text):Boolean;

फ़ाइल के अंत में फ़ाइल स्थिति सेट करता है

56

function SeekEOF: Boolean;

फ़ाइल के अंत में फ़ाइल स्थिति सेट करता है

57

function SeekEOLn(var t: Text):Boolean;

लाइन के अंत में फ़ाइल स्थिति सेट करता है

58

function SeekEOLn: Boolean;

लाइन के अंत में फ़ाइल स्थिति सेट करता है

59

procedure SetTextBuf(var f: Text; var Buf);

फ़ाइल बफ़र का आकार सेट करता है

60

procedure SetTextBuf(var f: Text; var Buf; Size: SizeInt);

फ़ाइल बफ़र का आकार सेट करता है

61

procedure Truncate(var F: file);

स्थिति पर फ़ाइल को काटें

62

procedure Write(Args: Arguments);

फाइल करने के लिए चर लिखता है

63

procedure Write(var F: Text; Args: Arguments);

फ़ाइल करने के लिए चर लिखें

64

procedure Writeln(Args: Arguments);

नई लाइन को फाइल और अपेंड करने के लिए वैरिएबल लिखते हैं

65

procedure WriteLn(var F: Text; Args: Arguments);

नई लाइन को फाइल और अपेंड करने के लिए वैरिएबल लिखते हैं

यह अध्याय पास्कल में गतिशील स्मृति प्रबंधन की व्याख्या करता है। पास्कल प्रोग्रामिंग भाषा मेमोरी आवंटन और प्रबंधन के लिए कई कार्य प्रदान करती है।

मेमोरी को गतिशील रूप से आवंटित करना

प्रोग्रामिंग करते समय, यदि आप किसी सरणी के आकार के बारे में जानते हैं, तो यह आसान है और आप इसे एक सरणी के रूप में परिभाषित कर सकते हैं। उदाहरण के लिए, किसी भी व्यक्ति के नाम को संग्रहीत करने के लिए, यह अधिकतम 100 वर्णों तक जा सकता है ताकि आप कुछ इस प्रकार परिभाषित कर सकें -

var
name: array[1..100] of char;

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

पास्कल एक प्रक्रिया प्रदान करता है newसूचक चर बनाने के लिए।

program exMemory;
var
name: array[1..100] of char;
description: ^string;

begin
   name:= 'Zara Ali';
   
   new(description);
      if not assigned(description) then
         writeln(' Error - unable to allocate required memory')
      else
         description^ := 'Zara ali a DPS student in class 10th';
   writeln('Name = ', name );
   writeln('Description: ', description^ );
end.

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

Name = Zara Ali
Description: Zara ali a DPS student in class 10th

अब, यदि आपको बाद में इसके द्वारा निर्दिष्ट किए जाने वाले विशिष्ट बाइट्स के साथ एक पॉइंटर को परिभाषित करने की आवश्यकता है, तो आपको इसका उपयोग करना चाहिए getmem समारोह या getmem प्रक्रिया, जिसमें निम्नलिखित सिंटैक्स है -

procedure Getmem(
   out p: pointer;
   Size: PtrUInt
);

function GetMem(
   size: PtrUInt
):pointer;

पिछले उदाहरण में, हमने एक स्ट्रिंग को पॉइंटर घोषित किया। एक स्ट्रिंग में अधिकतम 255 बाइट्स होते हैं। यदि आपको वास्तव में बाइट के संदर्भ में उस स्थान, या बड़े स्थान की आवश्यकता नहीं है, तो गेटम उपप्रोग्राम उस को निर्दिष्ट करने की अनुमति देता है। हम पिछले उदाहरण को फिर से लिखते हैं, getmem का उपयोग करते हुए -

program exMemory;
var
name: array[1..100] of char;
description: ^string;

begin
   name:= 'Zara Ali';
   
   description := getmem(200);
      if not assigned(description) then
         writeln(' Error - unable to allocate required memory')
      else
         description^ := 'Zara ali a DPS student in class 10th';
   writeln('Name = ', name );
   writeln('Description: ', description^ );
   
   freemem(description);
end.

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

Name = Zara Ali
Description: Zara ali a DPS student in class 10th

इसलिए, आपके पास पूर्ण नियंत्रण है और आप सरणियों के विपरीत मेमोरी आवंटित करते समय किसी भी आकार के मूल्य को पास कर सकते हैं, जहां एक बार आपने परिभाषित किया कि आकार नहीं बदला जा सकता है।

मेमोरी का आकार बदलना और जारी करना

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

पास्कल प्रक्रिया प्रदान करता है dispose प्रक्रिया का उपयोग कर एक गतिशील रूप से बनाए गए चर को मुक्त करने के लिए new. यदि आपने मेमोरी का उपयोग कर आवंटित किया है getmem उपप्रोग्राम, फिर आपको उपप्रोग्राम का उपयोग करने की आवश्यकता है freememइस स्मृति को मुक्त करने के लिए। Freemem subprograms निम्न सिंटैक्स है -

procedure Freemem(
   p: pointer;
  Size: PtrUInt
);

function Freemem(
   p: pointer
):PtrUInt;

वैकल्पिक रूप से, आप फ़ंक्शन ReAllocMem को कॉल करके आवंटित मेमोरी ब्लॉक के आकार को बढ़ा या घटा सकते हैं । आइए एक बार फिर उपरोक्त कार्यक्रम की जाँच करें और ReAllocMem और freemem उपप्रोग्राम का उपयोग करें । निम्नलिखित ReAllocMem के लिए वाक्य रचना है -

function ReAllocMem(
   var p: pointer;
   Size: PtrUInt
):pointer;

निम्नलिखित एक उदाहरण है जो ReAllocMem और freemem उपप्रोग्राम का उपयोग करता है -

program exMemory;
var
name: array[1..100] of char;
description: ^string;
desp: string;

begin
   name:= 'Zara Ali';
   desp := 'Zara ali a DPS student.';
   
   description := getmem(30);
      if not assigned(description) then
         writeln('Error - unable to allocate required memory')
      else
         description^ := desp;

   (* Suppose you want to store bigger description *)
   description := reallocmem(description, 100);
   desp := desp + ' She is in class 10th.';
   description^:= desp; 
   
   writeln('Name = ', name );
   writeln('Description: ', description^ );
   
   freemem(description);
end.

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

Name = Zara Ali
Description: Zara ali a DPS student. She is in class 10th

मेमोरी प्रबंधन कार्य

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

एस.एन. समारोह का नाम और विवरण
1

function Addr(X: TAnytype):Pointer;

चर का पता देता है

2

function Assigned(P: Pointer):Boolean;

चेक करता है कि कोई पॉइंटर मान्य है या नहीं

3

function CompareByte(const buf1; const buf2; len: SizeInt):SizeInt;

2 मेमोरी बफ़र्स प्रति बाइट की तुलना में

4

function CompareChar(const buf1; const buf2; len: SizeInt):SizeInt;

2 मेमोरी बफ़र्स प्रति बाइट की तुलना में

5

function CompareDWord(const buf1; const buf2; len: SizeInt):SizeInt;

2 मेमोरी बफ़र्स प्रति बाइट की तुलना में

6

function CompareWord(const buf1; const buf2; len: SizeInt):SizeInt;

2 मेमोरी बफ़र्स प्रति बाइट की तुलना में

7

function Cseg: Word;

कोड सेगमेंट लौटाता है

8

procedure Dispose(P: Pointer);

पेड़ों को गतिशील रूप से आवंटित स्मृति

9

procedure Dispose(P: TypedPointer; Des: TProcedure);

पेड़ों को गतिशील रूप से आवंटित स्मृति

10

function Dseg: Word;

डेटा खंड लौटाता है

1 1

procedure FillByte(var x; count: SizeInt; value: Byte);

8-बिट पैटर्न के साथ मेमोरी क्षेत्र को भरता है

12

procedure FillChar( var x; count: SizeInt; Value: Byte|Boolean|Char);

निश्चित क्षेत्र के साथ स्मृति क्षेत्र को भरता है

13

procedure FillDWord( var x; count: SizeInt; value: DWord);

32-बिट पैटर्न के साथ मेमोरी क्षेत्र को भरता है

14

procedure FillQWord( var x; count: SizeInt; value: QWord);

64-बिट पैटर्न के साथ मेमोरी क्षेत्र को भरता है

15 procedure FillWord( var x; count: SizeInt; Value: Word);

16-बिट पैटर्न के साथ मेमोरी क्षेत्र को भरता है

16

procedure Freemem( p: pointer; Size: PtrUInt);

स्मृतियों का आवंटन किया

17

procedure Freemem( p: pointer );

स्मृतियों का आवंटन किया

18

procedure Getmem( out p: pointer; Size: PtrUInt);

नई मेमोरी आवंटित करता है

19

procedure Getmem( out p: pointer);

नई मेमोरी आवंटित करता है

20

procedure GetMemoryManager( var MemMgr: TMemoryManager);

वर्तमान मेमोरी मैनेजर लौटाता है

21

function High( Arg: TypeOrVariable):TOrdinal;

ओपन ऐरे या एनुमरेटेड का उच्चतम सूचकांक लौटाता है

22

function IndexByte( const buf; len: SizeInt; b: Byte):SizeInt;

एक मेमोरी रेंज में बाइट के आकार का मूल्य पाता है

23

function IndexChar( const buf; len: SizeInt; b: Char):SizeInt;

एक स्मृति श्रेणी में चार-आकार का मूल्य प्राप्त करता है

24

function IndexDWord( const buf; len: SizeInt; b: DWord):SizeInt;

स्मृति सीमा में DWORD- आकार (32-बिट) मान प्राप्त करता है

25

function IndexQWord( const buf; len: SizeInt; b: QWord):SizeInt;

एक स्मृति सीमा में QWord- आकार का मूल्य पाता है

26

function Indexword( const buf; len: SizeInt; b: Word):SizeInt;

एक मेमोरी रेंज में शब्द-आकार मान को ढूँढता है

27

function IsMemoryManagerSet: Boolean;

मेमोरी मैनेजर सेट है

28

function Low( Arg: TypeOrVariable ):TOrdinal;

ओपन ऐरे या एनुमरेटेड का सबसे कम इंडेक्स देता है

29

procedure Move( const source; var dest; count: SizeInt );

मेमोरी में एक स्थान से दूसरे स्थान पर डेटा ले जाता है

30

procedure MoveChar0( const buf1; var buf2; len: SizeInt);

पहले शून्य वर्ण तक डेटा ले जाता है

31

procedure New( var P: Pointer);

चर के लिए डायनामिक रूप से मेमोरी आवंटित करें

32

procedure New( var P: Pointer; Cons: TProcedure);

चर के लिए डायनामिक रूप से मेमोरी आवंटित करता है

33

function Ofs( var X ):LongInt;

परिवर्तनशील की वापसी

34

function ptr( sel: LongInt; off: LongInt):farpointer;

सूचक के लिए खंड और ऑफसेट को जोड़ती है

35

function ReAllocMem( var p: pointer; Size: PtrUInt):pointer;

ढेर पर एक मेमोरी ब्लॉक का आकार बदलता है

36

function Seg( var X):LongInt;

सेगमेंट लौटाता है

37

procedure SetMemoryManager( const MemMgr: TMemoryManager );

एक मेमोरी मैनेजर सेट करता है

38

function Sptr: Pointer;

वर्तमान स्टैक पॉइंटर लौटाता है

39

function Sseg: Word;

स्टैक खंड खंड मान लौटाता है

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

निर्मित इकाइयों का उपयोग करना

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

program myprog;
uses crt;

निम्नलिखित उदाहरण का उपयोग करके दिखाता है crt इकाई -

Program Calculate_Area (input, output);
uses crt;
var 
   a, b, c, s, area: real;

begin
   textbackground(white); (* gives a white background *)
   clrscr; (*clears the screen *)
   
   textcolor(green); (* text color is green *)
   gotoxy(30, 4); (* takes the pointer to the 4th line and 30th column) 
   
   writeln('This program calculates area of a triangle:');
   writeln('Area = area = sqrt(s(s-a)(s-b)(s-c))');
   writeln('S stands for semi-perimeter');
   writeln('a, b, c are sides of the triangle');
   writeln('Press any key when you are ready');
   
   readkey;
   clrscr;
   gotoxy(20,3);
   
   write('Enter a: ');
   readln(a);
   gotoxy(20,5);
   
   write('Enter b:');
   readln(b);
   gotoxy(20, 7);
   
   write('Enter c: ');
   readln(c);

   s := (a + b + c)/2.0;
   area := sqrt(s * (s - a)*(s-b)*(s-c));
   gotoxy(20, 9);
   
   writeln('Area: ',area:10:3);
   readkey;
end.

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

पास्कल यूनिट बनाना और उपयोग करना

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

unit calculateArea;

पास्कल यूनिट बनाने में तीन महत्वपूर्ण चरण निम्नलिखित हैं -

  • फ़ाइल का नाम और यूनिट का नाम बिल्कुल एक जैसा होना चाहिए। तो, हमारी यूनिट कैलकुलेटआरेआ की गणना एक फाइल में की जाएगी, जिसका नाम कैलकरेरी.पास है।

  • अगली पंक्ति में एक एकल कीवर्ड होना चाहिए interface। इस पंक्ति के बाद, आप इस इकाई में आने वाले सभी कार्यों और प्रक्रियाओं के लिए घोषणाएँ लिखेंगे।

  • फ़ंक्शन घोषणाओं के ठीक बाद, शब्द लिखें implementation, जो फिर से एक कीवर्ड है। कीवर्ड कार्यान्वयन वाली रेखा के बाद, सभी उपप्रोग्राम की परिभाषा प्रदान करें।

निम्नलिखित कार्यक्रम की गणना करता है नामक इकाई बनाता है -

unit CalculateArea;
interface

function RectangleArea( length, width: real): real;
function CircleArea(radius: real) : real;
function TriangleArea( side1, side2, side3: real): real;

implementation

function RectangleArea( length, width: real): real;
begin
   RectangleArea := length * width;
end;

function CircleArea(radius: real) : real;
const
   PI = 3.14159;
begin
   CircleArea := PI * radius * radius;
end;

function TriangleArea( side1, side2, side3: real): real;
var
   s, area: real;

begin
   s := (side1 + side2 + side3)/2.0;
   area := sqrt(s * (s - side1)*(s-side2)*(s-side3));
   TriangleArea := area;
end;

end.

इसके बाद, हम एक सरल प्रोग्राम लिखते हैं जो हमारे द्वारा परिभाषित यूनिट का उपयोग करेगा -

program AreaCalculation;
uses CalculateArea,crt;

var
   l, w, r, a, b, c, area: real;

begin
   clrscr;
   l := 5.4;
   w := 4.7;
   area := RectangleArea(l, w);
   writeln('Area of Rectangle 5.4 x 4.7 is: ', area:7:3);

   r:= 7.0;
   area:= CircleArea(r);
   writeln('Area of Circle with radius 7.0 is: ', area:7:3);

   a := 3.0;
   b:= 4.0;
   c:= 5.0;
  
   area:= TriangleArea(a, b, c);
   writeln('Area of Triangle 3.0 by 4.0 by 5.0 is: ', area:7:3);
end.

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

Area of Rectangle 5.4 x 4.7 is: 25.380
Area of Circle with radius 7.0 is: 153.938
Area of Triangle 3.0 by 4.0 by 5.0 is: 6.000

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

वर्तमान तिथि और समय प्राप्त करना

पास्कल के टाइमटॉइरिंग फ़ंक्शन आपको एक कोलोन (:) सीमांकित रूप में वर्तमान समय देता है। निम्न उदाहरण दिखाता है कि वर्तमान समय कैसे प्राप्त किया जाए -

program TimeDemo;
uses sysutils;

begin
   writeln ('Current time : ',TimeToStr(Time));
end.

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

Current time : 18:33:08

Date फ़ंक्शन में वर्तमान दिनांक देता है TDateTimeप्रारूप। TDateTime एक दोहरा मूल्य है, जिसे कुछ डीकोडिंग और स्वरूपण की आवश्यकता होती है। निम्न कार्यक्रम दर्शाता है कि वर्तमान तिथि प्रदर्शित करने के लिए अपने कार्यक्रम में इसका उपयोग कैसे करें -

Program DateDemo;
uses sysutils;
var
   YY,MM,DD : Word;

begin
   writeln ('Date : ',Date);
   DeCodeDate (Date,YY,MM,DD);
   writeln (format ('Today is (DD/MM/YY): %d/%d/%d ',[dd,mm,yy]));
end.

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

Date: 4.111300000000000E+004
Today is (DD/MM/YY):23/7/2012

अब कार्य वर्तमान तिथि और समय लौटाता है -

Program DatenTimeDemo;
uses sysutils;
begin
   writeln ('Date and Time at the time of writing : ',DateTimeToStr(Now));
end.

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

Date and Time at the time of writing : 23/7/2012 18:51:

पास्कल नाम का एक सरल समय टिकट संरचना प्रदान करता है TTimeStamp, जिसका निम्न प्रारूप है -

type TTimeStamp = record
   Time: Integer;
   Date: Integer;
end;

विभिन्न तिथि और समय कार्य

नि: शुल्क पास्कल निम्नलिखित तारीख और समय कार्य प्रदान करता है -

अनु क्रमांक। समारोह का नाम और विवरण
1

function DateTimeToFileDate(DateTime: TDateTime):LongInt;

दिनांक समय फ़ाइल में कनवर्ट करता है।

2

function DateTimeToStr( DateTime: TDateTime):;

डेटाइम के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

3

function DateTimeToStr(DateTime: TDateTime; const FormatSettings: TFormatSettings):;

डेटाइम के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

4

procedure DateTimeToString(out Result: ;const FormatStr: ;const DateTime: TDateTime);

डेटाइम के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

5

procedure DateTimeToString(out Result: ; const FormatStr: ; const DateTime: TDateTime; const FormatSettings: TFormatSettings);

डेटाइम के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

6

procedure DateTimeToSystemTime(DateTime: TDateTime; out SystemTime: TSystemTime);

सिस्टम समय के लिए दिनांक समय देता है

7

function DateTimeToTimeStamp( DateTime: TDateTime):TTimeStamp;टाइमटाइम को डेटटाइम परिवर्तित करता है

8

function DateToStr(Date: TDateTime):;

तारीख के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

9

function DateToStr(Date: TDateTime; const FormatSettings: TFormatSettings):;

तारीख के स्ट्रिंग प्रतिनिधित्व का निर्माण करता है

10

function Date: TDateTime;

वर्तमान तिथि मिलती है

1 1

function DayOfWeek(DateTime: TDateTime):Integer;

सप्ताह का दिन हो जाता है

12

procedure DecodeDate(Date: TDateTime; out Year: Word; out Month: Word; out Day: Word);

वर्ष के महीने और दिन के लिए डेटटाइम को डिकोड करता है

13

procedure DecodeTime(Time: TDateTime; out Hour: Word; out Minute: Word; out Second: Word; out MilliSecond: Word);

डेटाइम को घंटे, मिनट और सेकंड तक

14

function EncodeDate(Year: Word; Month: Word; Day: Word):TDateTime;

वर्ष, दिन और महीने को डेटाइम को एन्कोड करता है

15

function EncodeTime(Hour: Word; Minute: Word; Second: Word; MilliSecond: Word):TDateTime;

डेटाइम के घंटे, मिनट और सेकंड को इनकोड करता है

16

function FormatDateTime(const FormatStr: ; DateTime: TDateTime):;

DateTime का स्ट्रिंग प्रतिनिधित्व लौटाता है

17

function FormatDateTime(const FormatStr: ; DateTime: TDateTime; const FormatSettings: TFormatSettings):;

DateTime का स्ट्रिंग प्रतिनिधित्व लौटाता है

18

function IncMonth(const DateTime: TDateTime; NumberOfMonths: Integer = 1):TDateTime;

1 से महीने जोड़ता है

19

function IsLeapYear(Year: Word):Boolean;

निर्धारित करता है कि वर्ष लीप वर्ष है

20

function MSecsToTimeStamp(MSecs: Comp):TTimeStamp;

मिलीसेकंड की संख्या को टाइमस्टैम्प में परिवर्तित करता है

21

function Now: TDateTime;

वर्तमान दिनांक और समय हो जाता है

22

function StrToDateTime(const S:):TDateTime;

स्ट्रिंग को डेटाइम में परिवर्तित करता है

23

function StrToDateTime(const s: ShortString; const FormatSettings: TFormatSettings):TDateTime;

स्ट्रिंग को डेटाइम में परिवर्तित करता है

24

function StrToDateTime(const s: AnsiString; const FormatSettings: TFormatSettings):TDateTime;

स्ट्रिंग को डेटाइम में परिवर्तित करता है

25

function StrToDate(const S: ShortString):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

26

function StrToDate(const S: Ansistring):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

27

function StrToDate(const S: ShortString; separator: Char):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

28

function StrToDate(const S: AnsiString; separator: Char):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

29

function StrToDate(const S: ShortString; const useformat: ; separator: Char):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

30

function StrToDate(const S: AnsiString; const useformat: ; separator: Char):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

31

function StrToDate(const S: PChar; Len: Integer; const useformat: ; separator: Char = #0):TDateTime;

स्ट्रिंग को आज तक परिवर्तित करता है

32

function StrToTime(const S: Shortstring):TDateTime;

स्ट्रिंग को समय पर बदलता है

33

function StrToTime(const S: Ansistring):TDateTime;

स्ट्रिंग को समय पर बदलता है

34

function StrToTime(const S: ShortString; separator: Char):TDateTime;

स्ट्रिंग को समय पर बदलता है

35

function StrToTime(const S: AnsiString; separator: Char):TDateTime;

स्ट्रिंग को समय पर बदलता है

36

function StrToTime(const S: ; FormatSettings: TFormatSettings):TDateTime;

स्ट्रिंग को समय पर बदलता है

37

function StrToTime(const S: PChar; Len: Integer; separator: Char = #0):TDateTime;

स्ट्रिंग को समय पर बदलता है

38

function SystemTimeToDateTime(const SystemTime: TSystemTime):TDateTime;

सिस्टम टाइम को डेटाइम में परिवर्तित करता है

39

function TimeStampToDateTime(const TimeStamp: TTimeStamp):TDateTime;

दिनांक समय पर मोहर लगाता है

40

function TimeStampToMSecs(const TimeStamp: TTimeStamp):comp;

मिलीसेकंड की संख्या के लिए टाइमस्टैम्प परिवर्तित करता है

41

function TimeToStr(Time: TDateTime):;

समय का स्ट्रिंग प्रतिनिधित्व लौटाता है

42

function TimeToStr(Time: TDateTime; const FormatSettings: TFormatSettings):;

समय का स्ट्रिंग प्रतिनिधित्व लौटाता है

43

function Time: TDateTime;

वर्तमान समय प्राप्त करें

निम्नलिखित उदाहरण उपरोक्त कार्यों में से कुछ का उपयोग दिखाता है -

Program DatenTimeDemo;
uses sysutils;
var
year, month, day, hr, min, sec, ms: Word;

begin
   writeln ('Date and Time at the time of writing : ',DateTimeToStr(Now));
   writeln('Today is ',LongDayNames[DayOfWeek(Date)]);
   writeln;
   writeln('Details of Date: ');
   
   DecodeDate(Date,year,month,day);
   writeln (Format ('Day: %d',[day]));
   writeln (Format ('Month: %d',[month]));
   writeln (Format ('Year: %d',[year]));
   writeln;
   writeln('Details of Time: ');
   
   DecodeTime(Time,hr, min, sec, ms);
   writeln (format('Hour: %d:',[hr]));
   writeln (format('Minutes: %d:',[min]));
   writeln (format('Seconds: %d:',[sec]));
   writeln (format('Milliseconds: %d:',[hr]));
end.

जब उपरोक्त कोड संकलित और निष्पादित किया गया था, तो उसने निम्नलिखित परिणाम प्रस्तुत किए:

Date and Time at the time of writing : 7/24/2012 8:26:
Today is Tuesday
Details of Date:
Day:24
Month:7
Year: 2012
Details of Time:
Hour: 8
Minutes: 26
Seconds: 21
Milliseconds: 8

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

  • वस्तु प्रकार
  • वर्ग प्रकार

ऑब्जेक्ट-ओरिएंटेड कॉन्सेप्ट्स

इससे पहले कि हम विस्तार से जाने, ऑब्जेक्ट-ओरिएंटेड पास्कल से संबंधित महत्वपूर्ण पास्कल शब्दों को परिभाषित करते हैं।

  • Object- एक ऑब्जेक्ट एक विशेष प्रकार का रिकॉर्ड होता है जिसमें रिकॉर्ड जैसे फ़ील्ड होते हैं; हालांकि, रिकॉर्ड के विपरीत, ऑब्जेक्ट में ऑब्जेक्ट के भाग के रूप में प्रक्रियाएं और कार्य शामिल हैं। इन प्रक्रियाओं और कार्यों को ऑब्जेक्ट के प्रकार से जुड़े तरीकों के संकेत के रूप में आयोजित किया जाता है।

  • Class- एक क्लास को ऑब्जेक्ट के रूप में लगभग उसी तरह से परिभाषित किया जाता है, लेकिन उनके बनाए जाने के तरीके में अंतर होता है। कक्षा को एक कार्यक्रम के ढेर पर आवंटित किया जाता है, जबकि ऑब्जेक्ट को स्टैक पर आवंटित किया जाता है। यह वस्तु का सूचक है, वस्तु का नहीं।

  • Instantiation of a class- तात्कालिकता का मतलब है कि उस वर्ग प्रकार का एक चर बनाना। चूंकि एक क्लास सिर्फ एक पॉइंटर है, जब एक क्लास टाइप का एक वैरिएबल घोषित किया जाता है, तो वहाँ पर केवल पॉइंटर के लिए आवंटित मेमोरी होती है, न कि पूरी ऑब्जेक्ट के लिए। केवल जब यह अपने किसी निर्माणकर्ता का उपयोग करके त्वरित किया जाता है, तो ऑब्जेक्ट के लिए मेमोरी आवंटित की जाती है। किसी वर्ग के उदाहरणों को 'ऑब्जेक्ट' भी कहा जाता है, लेकिन ऑब्जेक्ट पास्कल ऑब्जेक्ट्स के साथ उन्हें भ्रमित नहीं करते हैं। इस ट्यूटोरियल में, हम पास्कल ऑब्जेक्ट्स के लिए 'ऑब्जेक्ट' और वैचारिक ऑब्जेक्ट या क्लास उदाहरण के लिए 'ऑब्जेक्ट' लिखेंगे।

  • Member Variables - ये एक वर्ग या एक वस्तु के अंदर परिभाषित चर हैं।

  • Member Functions - ये क्लास या ऑब्जेक्ट के अंदर परिभाषित कार्य या प्रक्रियाएं हैं और इनका उपयोग ऑब्जेक्ट डेटा तक पहुंचने के लिए किया जाता है।

  • Visibility of Members- किसी ऑब्जेक्ट या क्लास के सदस्यों को फील्ड भी कहा जाता है। इन क्षेत्रों में अलग-अलग दृष्टिकोण हैं। दृश्यता सदस्यों की पहुंच को संदर्भित करती है, अर्थात, जहां ये सदस्य सुलभ होंगे। वस्तुओं के दृश्यता स्तर तीन होते हैं: सार्वजनिक, निजी और संरक्षित। कक्षाओं में पांच दृश्यता प्रकार होते हैं: सार्वजनिक, निजी, सख्ती से निजी, संरक्षित और प्रकाशित। हम विवरण में दृश्यता पर चर्चा करेंगे।

  • Inheritance- जब किसी अभिभावक वर्ग की मौजूदा कार्यप्रणाली को विरासत में देकर एक वर्ग को परिभाषित किया जाता है, तो उसे विरासत में कहा जाता है। यहां चाइल्ड क्लास सभी या कुछ सदस्य कार्यों और एक मूल वर्ग के चर का वारिस करेगी। वस्तुएं भी विरासत में मिल सकती हैं।

  • Parent Class- एक वर्ग जो दूसरे वर्ग को विरासत में मिला है। इसे बेस क्लास या सुपर क्लास भी कहा जाता है।

  • Child Class- एक वर्ग जो दूसरे वर्ग से विरासत में मिला है। इसे उपवर्ग या व्युत्पन्न वर्ग भी कहा जाता है।

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

  • Overloading- यह एक प्रकार का बहुरूपता है जिसमें कुछ या सभी ऑपरेटरों के पास उनके तर्कों के प्रकारों के आधार पर अलग-अलग कार्यान्वयन होते हैं। इसी तरह कार्यों को भी अलग-अलग कार्यान्वयन के साथ ओवरलोड किया जा सकता है। पास्कल कक्षाएं ओवरलोडिंग को लागू करती हैं, लेकिन ऑब्जेक्ट नहीं करते हैं।

  • Data Abstraction - डेटा का कोई प्रतिनिधित्व जिसमें कार्यान्वयन विवरण छिपा हुआ है (सार)।

  • Encapsulation - एक अवधारणा को संदर्भित करता है जहां हम एक वस्तु बनाने के लिए सभी डेटा और सदस्य कार्यों को एक साथ संलग्न करते हैं।

  • Constructor - एक विशेष प्रकार के फ़ंक्शन को संदर्भित करता है जिसे किसी वर्ग या ऑब्जेक्ट से ऑब्जेक्ट बनने पर स्वचालित रूप से कहा जाएगा।

  • Destructor - एक विशेष प्रकार के फ़ंक्शन को संदर्भित करता है जो किसी ऑब्जेक्ट या क्लास को हटाए जाने या दायरे से बाहर जाने पर स्वचालित रूप से कॉल किया जाएगा।

पास्कल वस्तुओं को परिभाषित करना

ऑब्जेक्ट को घोषणा प्रकार का उपयोग करके घोषित किया जाता है। वस्तु घोषणा का सामान्य रूप इस प्रकार है -

type object-identifier = object  
   private
   field1 : field-type;  
   field2 : field-type;  
   ...
   public
   procedure proc1;  
   function f1(): function-type;
   end;  
var objectvar : object-identifier;

आइए हम एक आयत वस्तु को परिभाषित करें जिसमें दो पूर्णांक प्रकार के डेटा सदस्य हों - length तथा width और कुछ सदस्य इन डेटा सदस्यों को हेरफेर करने के लिए और आयत को आकर्षित करने के लिए एक कार्य करते हैं।

type 
   Rectangle = object  
   private  
      length, width: integer; 
   
   public  
      constructor init;  
      destructor done;  
      
      procedure setlength(l: inteter);  
      function getlength(): integer;  
      
      procedure setwidth(w: integer);  
      function getwidth(): integer;  
      
      procedure draw;
end;
var
   r1: Rectangle;
   pr1: ^Rectangle;

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

निम्नलिखित उदाहरण से पता चलता है कि दो आयत वस्तुओं के लिए लंबाई और चौड़ाई कैसे सेट करें और सदस्य कार्यों को कॉल करके उन्हें आकर्षित करें।

r1.setlength(3);
r1.setwidth(7);

writeln(' Draw a rectangle: ', r1.getlength(), ' by ' , r1.getwidth());
r1.draw;
new(pr1);
pr1^.setlength(5);
pr1^.setwidth(4);

writeln(' Draw a rectangle: ', pr1^.getlength(), ' by ' ,pr1^.getwidth());
pr1^.draw;
dispose(pr1);

पास्कल में वस्तुओं का उपयोग कैसे करें, यह दिखाने के लिए एक पूर्ण उदाहरण निम्नलिखित है -

program exObjects;
type 
   Rectangle = object  
   private  
      length, width: integer; 
   
   public  
      procedure setlength(l: integer);
      function getlength(): integer;  
      
      procedure setwidth(w: integer);  
      function getwidth(): integer;  
      
      procedure draw;
end;
var
   r1: Rectangle;
   pr1: ^Rectangle;

procedure Rectangle.setlength(l: integer);
begin
   length := l;
end;

procedure Rectangle.setwidth(w: integer);
begin
   width :=w;
end;

function Rectangle.getlength(): integer;  
begin
   getlength := length;
end;

function Rectangle.getwidth(): integer;  
begin
   getwidth := width;
end;

procedure Rectangle.draw;
var 
   i, j: integer;
begin
   for i:= 1 to length do
   begin
     for j:= 1 to width do
        write(' * ');
     writeln;
   end;
end;

begin
   r1.setlength(3);
   r1.setwidth(7);
   
   writeln('Draw a rectangle:', r1.getlength(), ' by ' , r1.getwidth());
   r1.draw;
   new(pr1);
   pr1^.setlength(5);
   pr1^.setwidth(4);
   
   writeln('Draw a rectangle:', pr1^.getlength(), ' by ' ,pr1^.getwidth());
   pr1^.draw;
   dispose(pr1);
end.

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

Draw a rectangle: 3 by 7
* * * * * * *
* * * * * * *
* * * * * * *
Draw a rectangle: 5 by 4
* * * *
* * * *
* * * *
* * * *
* * * *

वस्तु सदस्यों की दृश्यता

दृश्यता ऑब्जेक्ट सदस्यों की पहुंच को इंगित करता है। पास्कल ऑब्जेक्ट सदस्यों की दृश्यता तीन प्रकार की होती है -

अनु क्रमांक दृश्यता और पहुंच
1

Public

सदस्यों का उपयोग प्रोग्राम यूनिट के बाहर अन्य इकाइयों द्वारा किया जा सकता है

2

Private

सदस्य केवल वर्तमान इकाई में ही सुलभ हैं।

3

Protected

सदस्य केवल मूल वस्तु से उतरे हुए वस्तुओं के लिए उपलब्ध हैं।

डिफ़ॉल्ट रूप से, किसी ऑब्जेक्ट के फ़ील्ड और तरीके सार्वजनिक होते हैं और वर्तमान इकाई के बाहर निर्यात किए जाते हैं।

पास्कल वस्तुओं के लिए निर्माणकर्ता और विध्वंसक -

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

Destructorsवे विधियाँ हैं जिन्हें वस्तु के विनाश के दौरान कहा जाता है। विध्वंसक विधियां निर्माणकर्ताओं द्वारा बनाए गए किसी भी स्मृति आवंटन को नष्ट कर देती हैं।

उदाहरण के बाद, आयत वर्ग के लिए एक निर्माणकर्ता और एक विध्वंसक प्रदान करेगा जो ऑब्जेक्ट निर्माण के समय आयत के लिए लंबाई और चौड़ाई को इनिशियलाइज़ करेगा और जब यह दायरे से बाहर हो जाएगा तो इसे नष्ट कर देगा।

program exObjects;
type 
   Rectangle = object  
   private  
      length, width: integer; 
   public  
      constructor init(l, w: integer);
      destructor done;
      
      procedure setlength(l: integer);
      function getlength(): integer;  
      
      procedure setwidth(w: integer);  
      function getwidth(): integer;  
      
      procedure draw;
end;

var
   r1: Rectangle;
   pr1: ^Rectangle;

constructor Rectangle.init(l, w: integer);
begin
   length := l;
   width := w;
end;

destructor Rectangle.done;
begin
   writeln(' Desctructor Called');
end; 

procedure Rectangle.setlength(l: integer);
begin
   length := l;
end;

procedure Rectangle.setwidth(w: integer);
begin
   width :=w;
end;

function Rectangle.getlength(): integer;  
begin
   getlength := length;
end;

function Rectangle.getwidth(): integer;  
begin
   getwidth := width;
end;

procedure Rectangle.draw;
var 
   i, j: integer;
begin
   for i:= 1 to length do
   begin
      for j:= 1 to width do
         write(' * ');
      writeln;
   end;
end;

begin
   r1.init(3, 7);
   writeln('Draw a rectangle:', r1.getlength(), ' by ' , r1.getwidth());
   r1.draw;
   new(pr1, init(5, 4));
   
   writeln('Draw a rectangle:', pr1^.getlength(), ' by ',pr1^.getwidth());
   pr1^.draw;
   pr1^.init(7, 9);
   
   writeln('Draw a rectangle:', pr1^.getlength(), ' by ' ,pr1^.getwidth());
   pr1^.draw;
   dispose(pr1);
   r1.done;
end.

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

Draw a rectangle: 3 by 7
* * * * * * *
* * * * * * *
* * * * * * *
Draw a rectangle: 5 by 4
* * * *
* * * *
* * * *
* * * *
* * * *
Draw a rectangle: 7 by 9
* * * * * * * * *
* * * * * * * * *
* * * * * * * * *
* * * * * * * * *
* * * * * * * * *
* * * * * * * * *
* * * * * * * * *
Destructor Called

पास्कल वस्तुओं के लिए विरासत

पास्कल ऑब्जेक्ट वैकल्पिक रूप से मूल वस्तु से विरासत में मिल सकते हैं। निम्नलिखित कार्यक्रम पास्कल वस्तुओं में विरासत को दर्शाता है। हमें नाम की एक और वस्तु बनाते हैंTableTop, जो आयत वस्तु से विरासत में मिला है।

program exObjects;
type 
   Rectangle = object  
   private  
      length, width: integer; 
   public  
      procedure setlength(l: integer);  
      function getlength(): integer;  
      procedure setwidth(w: integer);  
      function getwidth(): integer;  
      procedure draw;
end;

TableTop = object (Rectangle)
   private
     material: string;
   public
      function getmaterial(): string;
      procedure setmaterial( m: string);
      procedure displaydetails;
      procedure draw;
end;

var
   tt1: TableTop;

procedure Rectangle.setlength(l: integer);
begin
   length := l;
end;

procedure Rectangle.setwidth(w: integer);
begin
   width :=w;
end;

function Rectangle.getlength(): integer;  
begin
   getlength := length;
end;

function Rectangle.getwidth():integer;
begin
   getwidth := width;
end;

procedure Rectangle.draw;
var 
   i, j: integer;
begin
   for i:= 1 to length do
   begin
      for j:= 1 to width do
         write(' * ');
      writeln;
  end;
end;

function TableTop.getmaterial(): string;
begin
   getmaterial := material;
end;

procedure TableTop.setmaterial( m: string);
begin
   material := m;
end;

procedure TableTop.displaydetails;
begin
   writeln('Table Top: ', self.getlength(), ' by ' , self.getwidth());
   writeln('Material: ', self.getmaterial());
end;

procedure TableTop.draw();
var
   i, j: integer;
begin
   for i:= 1 to length do
   begin
      for j:= 1 to width do
         write(' * ');
   writeln;
   end;
   writeln('Material: ', material);
end;

begin
   tt1.setlength(3);
   tt1.setwidth(7);
   tt1.setmaterial('Wood');
   tt1.displaydetails();
   writeln;
   writeln('Calling the Draw method');
   tt1.draw();
end.

निम्नलिखित महत्वपूर्ण बिंदु हैं जिन पर ध्यान दिया जाना चाहिए -

  • ऑब्जेक्ट टेबलटॉप को आयत वस्तु के सभी सदस्यों को विरासत में मिला है।

  • टेबलटॉप में भी एक ड्रा विधि है । जब ड्रा विधि एक का उपयोग कर कहा जाता है टेबलटॉप वस्तु, tabletop के ड्रा लागू हो जाता है।

  • नाम का एक निहित उदाहरण है self यह वस्तु के वर्तमान उदाहरण को संदर्भित करता है।

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

Table Top: 3 by 7
Material: Wood

Calling the Draw Method 
* * * * * * *
* * * * * * *
* * * * * * *
Material: Wood

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

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

पास्कल कक्षाएं परिभाषित करना

एक वर्ग को ऑब्जेक्ट के रूप में उसी तरह घोषित किया जाता है, जिस प्रकार की घोषणा। वर्ग घोषणा का सामान्य रूप इस प्रकार है -

type class-identifier = class  
   private
      field1 : field-type;  
      field2 : field-type;  
        ...
   
   public
      constructor create();
      procedure proc1;  
      function f1(): function-type;
end;  
var classvar : class-identifier;

महत्वपूर्ण बिंदुओं पर ध्यान देने योग्य है -

  • कक्षा की परिभाषाएँ केवल कार्यक्रम के घोषित घोषणा भाग के अंतर्गत आनी चाहिए।

  • का उपयोग करके एक वर्ग को परिभाषित किया गया है class कीवर्ड।

  • फ़ील्ड डेटा आइटम हैं जो कक्षा के प्रत्येक उदाहरण में मौजूद हैं।

  • किसी वर्ग की परिभाषा के भीतर तरीके घोषित किए जाते हैं।

  • एक पूर्वनिर्धारित कंस्ट्रक्टर है जिसे कहा जाता है Createजड़ वर्ग में। हर अमूर्त वर्ग और हर ठोस वर्ग रूट का वंशज है, इसलिए सभी वर्गों में कम से कम एक निर्माता है।

  • एक पूर्वनिर्धारित विध्वंसक कहा जाता है Destroyजड़ वर्ग में। हर अमूर्त वर्ग और हर ठोस वर्ग रूट का वंशज है, इसलिए, सभी वर्गों में कम से कम एक विध्वंसक है।

आइए हम एक आयत वर्ग को परिभाषित करते हैं जिसमें दो पूर्णांक प्रकार के डेटा सदस्य होते हैं - लंबाई और चौड़ाई और इन डेटा सदस्यों को हेरफेर करने के लिए कुछ सदस्य फ़ंक्शन और आयत को आकर्षित करने के लिए एक प्रक्रिया।

type
   Rectangle = class
   private
      length, width: integer;
   
   public
      constructor create(l, w: integer);
      procedure setlength(l: integer);
      function getlength(): integer;
      procedure setwidth(w: integer);
      function getwidth(): integer;
      procedure draw;
end;

आइए हम एक संपूर्ण कार्यक्रम लिखते हैं जो आयत वर्ग का एक उदाहरण बनायेगा और आयत को खींचेगा। यह वही उदाहरण है जिसका उपयोग हमने पास्कल वस्तुओं पर चर्चा करते समय किया था। आप पाएंगे कि दोनों कार्यक्रम लगभग समान हैं, निम्नलिखित अपवादों के साथ -

  • आपको कक्षाओं का उपयोग करने के लिए {$ मोड objfpc} निर्देश को शामिल करने की आवश्यकता होगी।

  • आपको कंस्ट्रक्टर का उपयोग करने के लिए {$ m +} निर्देश को शामिल करना होगा।

  • क्लास इंस्टेंटेशन ऑब्जेक्ट इंस्टेंटेशन से अलग है। केवल चर घोषित करने से उदाहरण के लिए जगह नहीं बनती है, आप मेमोरी को आवंटित करने के लिए निर्माणकर्ता का उपयोग करेंगे।

यहाँ पूरा उदाहरण है -

{$mode objfpc} // directive to be used for defining classes {$m+}		   // directive to be used for using constructor

program exClass;
type
   Rectangle = class
   private
      length, width: integer;
   
   public
      constructor create(l, w: integer);
      procedure setlength(l: integer);
      
      function getlength(): integer;
      procedure setwidth(w: integer);
      
      function getwidth(): integer;
      procedure draw;
end;
var
   r1: Rectangle;

constructor Rectangle.create(l, w: integer);
begin
   length := l;
   width := w;
end;

procedure Rectangle.setlength(l: integer);
begin
   length := l;
end;

procedure Rectangle.setwidth(w: integer);
begin
   width :=w;
end;

function Rectangle.getlength(): integer;
begin
   getlength := length;
end;

function Rectangle.getwidth(): integer;
begin
   getwidth := width;
end;

procedure Rectangle.draw;
var
   i, j: integer;
begin
   for i:= 1 to length do
   begin
      for j:= 1 to width do
         write(' * ');
      writeln;
   end;
end;

begin
   r1:= Rectangle.create(3, 7);
   
   writeln(' Draw Rectangle: ', r1.getlength(), ' by ' , r1.getwidth());
   r1.draw;
   r1.setlength(4);
   r1.setwidth(6);
   
   writeln(' Draw Rectangle: ', r1.getlength(), ' by ' , r1.getwidth());
   r1.draw;
end.

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

Draw Rectangle: 3 by 7
* * * * * * *
* * * * * * *
* * * * * * *
Draw Rectangle: 4 by 6
* * * * * * 
* * * * * * 
* * * * * * 
* * * * * *

कक्षा सदस्यों की दृश्यता

दृश्यता कक्षा के सदस्यों की पहुंच को इंगित करती है। पास्कल वर्ग के सदस्यों की दृश्यता पांच प्रकार की होती है -

अनु क्रमांक दृश्यता और पहुंच
1

Public

ये सदस्य हमेशा सुलभ होते हैं।

2

Private

इन सदस्यों को केवल उस मॉड्यूल या यूनिट में एक्सेस किया जा सकता है जिसमें कक्षा की परिभाषा है। उन्हें कक्षा के तरीकों के अंदर या उनके बाहर से एक्सेस किया जा सकता है।

3

Strict Private

इन सदस्यों को केवल कक्षा के तरीकों से ही पहुँचा जा सकता है। एक ही इकाई में अन्य वर्ग या अवरोही वर्ग उन तक नहीं पहुँच सकते हैं।

4

Protected

यह निजी के समान है, सिवाय इसके, ये सदस्य अवरोही प्रकारों के लिए सुलभ हैं, भले ही वे अन्य मॉड्यूल में लागू किए गए हों।

5

Published

यह एक सार्वजनिक के समान है, लेकिन कंपाइलर टाइप जानकारी उत्पन्न करता है जो इन वर्गों के स्वचालित स्ट्रीमिंग के लिए आवश्यक है यदि कंपाइलर {$ M +} राज्य में है। प्रकाशित अनुभाग में परिभाषित फ़ील्ड्स वर्ग प्रकार के होने चाहिए।

पास्कल क्लासेस के लिए कंस्ट्रक्टर और डिस्ट्रक्टर्स

कंस्ट्रक्टर विशेष विधियाँ हैं, जो जब भी कोई वस्तु बनाई जाती हैं, स्वचालित रूप से कहलाती हैं। इसलिए हम निर्माण कार्यों के माध्यम से कई चीजों को शुरू करके इस व्यवहार का पूरा लाभ उठाते हैं।

पास्कल एक रचनाकार को परिभाषित करने के लिए क्रिएट () नामक एक विशेष फ़ंक्शन प्रदान करता है। कंस्ट्रक्टर फंक्शन में आप जितने चाहें उतने तर्क पारित कर सकते हैं।

उदाहरण के बाद, बुक्स नामक एक वर्ग के लिए एक कंस्ट्रक्टर बनाया जाएगा और यह ऑब्जेक्ट निर्माण के समय पुस्तक के लिए मूल्य और शीर्षक को इनिशियलाइज़ करेगा।

program classExample;

{$MODE OBJFPC} //directive to be used for creating classes
{$M+} //directive that allows class constructors and destructors
type
   Books = Class 
   private 
      title : String; 
      price: real;
   
   public
      constructor Create(t : String; p: real); //default constructor
      
      procedure setTitle(t : String); //sets title for a book
      function getTitle() : String; //retrieves title
      
      procedure setPrice(p : real); //sets price for a book
      function getPrice() : real; //retrieves price
      
      procedure Display(); // display details of a book
end;
var
   physics, chemistry, maths: Books;

//default constructor 
constructor Books.Create(t : String; p: real);
begin
   title := t;
   price := p;
end;

procedure Books.setTitle(t : String); //sets title for a book
begin
   title := t;
end;

function Books.getTitle() : String; //retrieves title
begin
   getTitle := title;
end;

procedure Books.setPrice(p : real); //sets price for a book
begin
   price := p;
end;

function Books.getPrice() : real; //retrieves price
begin
   getPrice:= price;
end;

procedure Books.Display();
begin
   writeln('Title: ', title);
   writeln('Price: ', price:5:2);
end;

begin 
   physics := Books.Create('Physics for High School', 10);
   chemistry := Books.Create('Advanced Chemistry', 15);
   maths := Books.Create('Algebra', 7);
   
   physics.Display;
   chemistry.Display;
   maths.Display;
end.

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

Title: Physics for High School
Price: 10
Title: Advanced Chemistry
Price: 15
Title: Algebra
Price: 7

निर्माण नामांकित निहित निर्माता की तरह, एक अंतर्निहित विध्वंसक विधि भी है जिसका उपयोग करके आप कक्षा में उपयोग किए गए सभी संसाधनों को जारी कर सकते हैं।

विरासत

पास्कल श्रेणी की परिभाषाएं मूल रूप से मूल श्रेणी की परिभाषा से ली जा सकती हैं। वाक्य विन्यास इस प्रकार है -

type
childClas-identifier = class(baseClass-identifier) 
< members >
end;

निम्नलिखित उदाहरण एक उपन्यास वर्ग प्रदान करता है, जो पुस्तकें वर्ग को विरासत में देता है और आवश्यकता के आधार पर अधिक कार्यक्षमता जोड़ता है।

program inheritanceExample;

{$MODE OBJFPC} //directive to be used for creating classes
{$M+} //directive that allows class constructors and destructors

type
   Books = Class 
   protected 
      title : String; 
      price: real;
   
   public
      constructor Create(t : String; p: real); //default constructor
      
      procedure setTitle(t : String); //sets title for a book
      function getTitle() : String; //retrieves title
      
      procedure setPrice(p : real); //sets price for a book
      function getPrice() : real; //retrieves price
      
      procedure Display(); virtual; // display details of a book
end;
(* Creating a derived class *)

type
   Novels = Class(Books)
   private
      author: String;
   
   public
      constructor Create(t: String); overload;
      constructor Create(a: String; t: String; p: real); overload;
      
      procedure setAuthor(a: String); // sets author for a book
      function getAuthor(): String; // retrieves author name
      
      procedure Display(); override;
end;
var
   n1, n2: Novels;

//default constructor 
constructor Books.Create(t : String; p: real);
begin
   title := t;
   price := p;
end;

procedure Books.setTitle(t : String); //sets title for a book
begin
   title := t;
end;

function Books.getTitle() : String; //retrieves title
begin
   getTitle := title;
end;

procedure Books.setPrice(p : real); //sets price for a book
begin
   price := p;
end;

function Books.getPrice() : real; //retrieves price
begin
   getPrice:= price;
end;

procedure Books.Display();
begin
   writeln('Title: ', title);
   writeln('Price: ', price);
end;

(* Now the derived class methods  *)
constructor Novels.Create(t: String);
begin
   inherited Create(t, 0.0);
   author:= ' ';
end;

constructor Novels.Create(a: String; t: String; p: real);
begin
   inherited Create(t, p);
   author:= a;
end;

procedure Novels.setAuthor(a : String); //sets author for a book
begin
   author := a;
end;

function Novels.getAuthor() : String; //retrieves author
begin
   getAuthor := author;
end;

procedure Novels.Display();
begin
   writeln('Title: ', title);
   writeln('Price: ', price:5:2);
   writeln('Author: ', author);
end;

begin 
   n1 := Novels.Create('Gone with the Wind');
   n2 := Novels.Create('Ayn Rand','Atlas Shrugged', 467.75);
   n1.setAuthor('Margaret Mitchell');
   n1.setPrice(375.99);
   n1.Display;
   n2.Display;
end.

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

Title: Gone with the Wind
Price: 375.99
Author: Margaret Mitchell
Title: Atlas Shrugged
Price: 467.75
Author: Ayn Rand

महत्वपूर्ण बिंदुओं पर ध्यान देने योग्य है -

  • बुक्स क्लास के सदस्यों के पास है protected दृश्यता।

  • नॉवेल्स क्लास में दो कंस्ट्रक्टर हैं, इसलिए overload ऑपरेटर का उपयोग फ़ंक्शन ओवरलोडिंग के लिए किया जाता है।

  • Books.Display प्रक्रिया घोषित की गई है virtual, ताकि नोवेल क्लास से एक ही विधि हो सके override यह।

  • नॉवेलसक्रिएट कंस्ट्रक्टर बेस क्लास कंस्ट्रक्टर का उपयोग करके कॉल करता है inherited कीवर्ड।

इंटरफेस

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

type  
   Mail = Interface  
      Procedure SendMail;  
      Procedure GetMail;  
   end;  
   
   Report = Class(TInterfacedObject,  Mail)  
      Procedure SendMail;  
      Procedure GetMail;  
   end;

कृपया ध्यान दें कि जब कोई वर्ग इंटरफ़ेस लागू करता है, तो उसे इंटरफ़ेस के सभी तरीकों को लागू करना चाहिए। यदि इंटरफ़ेस का एक तरीका लागू नहीं किया गया है, तो कंपाइलर एक त्रुटि देगा।

सार वर्ग

एक अमूर्त वर्ग वह है जिसे तात्कालिक नहीं किया जा सकता है, केवल विरासत में मिला है। एक अमूर्त वर्ग इस तरह से वर्ग परिभाषा में शब्द प्रतीक सार सहित निर्दिष्ट किया जाता है -

type
   Shape = ABSTRACT CLASS (Root)
      Procedure draw; ABSTRACT;
      ...
   end;

जब एक अमूर्त वर्ग से विरासत में मिला, तो माता-पिता की कक्षा की घोषणा में सार के सभी तरीकों को बच्चे द्वारा परिभाषित किया जाना चाहिए; इसके अलावा, इन तरीकों को समान दृश्यता के साथ परिभाषित किया जाना चाहिए।

स्थैतिक खोजशब्द

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

program StaticExample;
{$mode objfpc}
{$static on}
type
   myclass=class
      num : integer;static;
   end;
var
   n1, n2 : myclass;
begin
   n1:= myclass.create;
   n2:= myclass.create;
   n1.num := 12;
   writeln(n2.num);
   n2.num := 31;
   writeln(n1.num);
   writeln(myclass.num);
   myclass.num := myclass.num + 20;
   writeln(n1.num);
   writeln(n2.num);
end.

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

12
31
31
51
51

स्थैतिक सदस्यों का उपयोग करने के लिए आपको निर्देश {$ स्थैतिक पर} का उपयोग करना चाहिए।