पास्कल - रिकॉर्ड
पास्कल सरणियाँ आपको एक ही प्रकार के कई डेटा आइटम धारण करने की अनुमति देती हैं, लेकिन एक रिकॉर्ड एक अन्य उपयोगकर्ता-परिभाषित डेटा प्रकार पास्कल में उपलब्ध है जो आपको विभिन्न प्रकार के डेटा आइटम को संयोजित करने की अनुमति देता है।
रिकॉर्ड में अलग-अलग क्षेत्र शामिल हैं। मान लीजिए कि आप अपनी पुस्तकों का विवरण किसी पुस्तकालय में रखना चाहते हैं, तो आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक कर सकते हैं -
- 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.
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
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
रिकॉर्ड करने के लिए संकेत
आप पॉइंटर्स को रिकॉर्ड में उसी तरह से परिभाषित कर सकते हैं जैसे आप किसी अन्य चर के लिए पॉइंटर को परिभाषित करते हैं -
type
record-ptr = ^ record-name;
record-name = record
field-1: field-type1;
field-2: field-type2;
...
field-n: field-typen;
end;
अब, आप उपरोक्त परिभाषित सूचक चर में एक रिकॉर्ड प्रकार चर के पते को संग्रहीत कर सकते हैं। बनाए गए पॉइंटर प्रकार के एक वैरिएबल को घोषित करने के लिए, आप var कीवर्ड का उपयोग करते हैं -
var
r1, r2, ... : record-ptr;
इन बिंदुओं का उपयोग करने से पहले, आपको एक रिकॉर्ड-नाम प्रकार चर के लिए भंडारण बनाना होगा, जिसे इन बिंदुओं द्वारा हेरफेर किया जाएगा।
new(r1);
new(r2);
उस रिकॉर्ड के लिए एक पॉइंटर का उपयोग करके रिकॉर्ड के सदस्यों तक पहुंचने के लिए, आपको ^ का उपयोग करना होगा। ऑपरेटर निम्नानुसार है -
r1^.feild1 := value1;
r1^.feild2 := value2;
...
r1^fieldn := valuen;
अंत में, उपयोग किए गए संग्रहण को निपटाना न भूलें, जब यह अब उपयोग में नहीं है -
dispose(r1);
dispose(r2);
आइए किताबों के रिकॉर्ड के लिए एक पॉइंटर का उपयोग करके पहला उदाहरण फिर से लिखें। आशा है कि इस अवधारणा को समझना आपके लिए आसान होगा -
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.
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
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
स्टेटमेंट के साथ
हमने चर्चा की है कि एक रिकॉर्ड के सदस्यों को सदस्य एक्सेस ऑपरेटर (?) का उपयोग करके एक्सेस किया जा सकता है। इस तरह हर बार रिकॉर्ड चर का नाम लिखना होता है। With बयान ऐसा करने का एक वैकल्पिक तरीका प्रदान करता है।
हमारे पहले उदाहरण से लिए गए निम्नलिखित कोड स्निपेट को देखें -
(* book 1 specification *)
Book1.title := 'C Programming';
Book1.author := 'Nuha Ali ';
Book1.subject := 'C Programming Tutorial';
Book1.book_id := 6495407;
उसी असाइनमेंट को उपयोग करके लिखा जा सकता है With बयान के रूप में -
(* book 1 specification *)
With Book1 do
begin
title := 'C Programming';
author := 'Nuha Ali ';
subject := 'C Programming Tutorial';
book_id := 6495407;
end;