Pascal - คู่มือฉบับย่อ

ภาษาปาสคาลเป็นภาษาระดับสูงที่ใช้งานทั่วไปซึ่งพัฒนาโดย Niklaus Wirth ในช่วงต้นทศวรรษ 1970 ได้รับการพัฒนาขึ้นเพื่อการสอนการเขียนโปรแกรมเพื่อสร้างวินัยอย่างเป็นระบบและเพื่อพัฒนาโปรแกรมที่เชื่อถือได้และมีประสิทธิภาพ

Pascal เป็นภาษาที่ใช้ Algol และมีโครงสร้างหลายอย่างของ Algol Algol 60 เป็นส่วนย่อยของ Pascal Pascal มีข้อมูลหลายประเภทและโครงสร้างการเขียนโปรแกรม ง่ายต่อการทำความเข้าใจและบำรุงรักษาโปรแกรมภาษาปาสคาล

ปาสคาลได้รับความนิยมในเวทีการเรียนการสอนและวิชาการด้วยเหตุผลหลายประการ:

  • ง่ายต่อการเรียนรู้
  • ภาษาที่มีโครงสร้าง
  • สร้างโปรแกรมที่โปร่งใสมีประสิทธิภาพและเชื่อถือได้
  • สามารถรวบรวมได้บนแพลตฟอร์มคอมพิวเตอร์ที่หลากหลาย

คุณสมบัติของภาษาปาสคาล

Pascal มีคุณสมบัติดังต่อไปนี้ -

  • ภาษาปาสคาลเป็นภาษาที่พิมพ์อย่างรุนแรง
  • มีการตรวจสอบข้อผิดพลาดมากมาย
  • มีข้อมูลหลายประเภทเช่นอาร์เรย์ระเบียนไฟล์และชุด
  • มีโครงสร้างการเขียนโปรแกรมที่หลากหลาย
  • สนับสนุนการเขียนโปรแกรมเชิงโครงสร้างผ่านฟังก์ชันและขั้นตอน
  • รองรับการเขียนโปรแกรมเชิงวัตถุ

ข้อเท็จจริงเกี่ยวกับภาษาปาสคาล

  • ภาษา Pascal ได้รับการตั้งชื่อตาม Blaise Pascal นักคณิตศาสตร์ชาวฝรั่งเศสและเป็นผู้บุกเบิกการพัฒนาคอมพิวเตอร์

  • Niklaus Wirth เสร็จสิ้นการพัฒนาภาษาโปรแกรม Pascal ดั้งเดิมในปี 1970

  • ภาษาปาสคาลเป็นไปตามรูปแบบโครงสร้างบล็อกของภาษาโปรแกรม Algol

  • ภาษาปาสคาลได้รับการพัฒนาให้เป็นภาษาที่เหมาะสำหรับการสอนการเขียนโปรแกรมโดยมีระเบียบวินัยอย่างเป็นระบบซึ่งการนำไปใช้นั้นมีความน่าเชื่อถือและมีประสิทธิภาพ

  • มาตรฐาน ISO 7185 Pascal ได้รับการตีพิมพ์ครั้งแรกในปี 1983

  • ภาษาปาสคาลเป็นภาษาระดับสูงหลักที่ใช้สำหรับการพัฒนาใน Apple Lisa และในช่วงปีแรก ๆ ของ Mac

  • ในปี 1986 Apple Computer ได้เปิดตัวการใช้งาน Object Pascal เป็นครั้งแรกและในปี 1993 คณะกรรมการมาตรฐาน Pascal ได้เผยแพร่การขยาย Object-Oriented Extension ไปยัง Pascal

ทำไมต้องใช้ Pascal?

ภาษาปาสคาลช่วยให้โปรแกรมเมอร์สามารถกำหนดประเภทข้อมูลที่มีโครงสร้างซับซ้อนและสร้างโครงสร้างข้อมูลแบบไดนามิกและเรียกซ้ำเช่นรายการต้นไม้และกราฟ Pascal มีคุณสมบัติเช่นเร็กคอร์ดการแจงนับย่อยตัวแปรที่จัดสรรแบบไดนามิกพร้อมด้วยพอยน์เตอร์และชุดที่เกี่ยวข้อง

ภาษาปาสคาลอนุญาตให้กำหนดขั้นตอนที่ซ้อนกันในระดับความลึกใด ๆ นี่เป็นสภาพแวดล้อมการเขียนโปรแกรมที่ยอดเยี่ยมอย่างแท้จริงสำหรับการเรียนรู้การเขียนโปรแกรมเป็นระเบียบวินัยอย่างเป็นระบบตามแนวคิดพื้นฐาน

ในการใช้งานที่น่าทึ่งที่สุดของ Pascal ได้แก่ -

  • Skype
  • ผู้บัญชาการทั้งหมด
  • TeX
  • Macromedia Captivate
  • แอปเปิ้ลลิซ่า
  • เกมพีซีต่างๆ
  • ระบบฝังตัว

มีคอมไพเลอร์และตัวแปลภาษาปาสคาลหลายตัวสำหรับการใช้งานทั่วไป ในจำนวนนี้ ได้แก่ -

  • Turbo Pascal - จัดเตรียม IDE และคอมไพเลอร์สำหรับรันโปรแกรม Pascal บน CP / M, CP / M-86, DOS, Windows และ Macintosh

  • Delphi- จัดเตรียมคอมไพเลอร์สำหรับเรียกใช้ Object Pascal และสร้างโค้ดเนทีฟสำหรับระบบปฏิบัติการ Windows 32 บิตและ 64 บิตรวมถึง MacOS X และ iOS แบบ 32 บิต Embarcadero กำลังวางแผนที่จะสร้างการสนับสนุนสำหรับระบบปฏิบัติการ Linux และ Android

  • Free Pascal- เป็นคอมไพเลอร์ฟรีสำหรับรันโปรแกรม Pascal และ Object Pascal ฟรีคอมไพเลอร์ Pascal เป็นคอมไพเลอร์ Pascal แบบ Turbo Pascal และ Delphi 32 บิตและ 64 บิตสำหรับ Linux, Windows, OS / 2, FreeBSD, MacOS X, DOS และแพลตฟอร์มอื่น ๆ

  • Turbo51 - เป็นคอมไพเลอร์ Pascal ฟรีสำหรับไมโครคอนโทรลเลอร์ตระกูล 8051 พร้อมไวยากรณ์ Turbo Pascal 7

  • Oxygene - เป็นคอมไพเลอร์ Object Pascal สำหรับแพลตฟอร์ม. NET และ Mono

  • GNU Pascal (GPC) - เป็นคอมไพเลอร์ Pascal ที่ประกอบด้วยส่วนหน้าของ GNU Compiler Collection

เราจะใช้ Free Pascal ในบทช่วยสอนเหล่านี้ คุณสามารถดาวน์โหลด Free Pascal สำหรับระบบปฏิบัติการของคุณได้จากลิงค์: ดาวน์โหลด Free Pascal

การติดตั้ง Free Pascal บน Linux

การแจกจ่าย Free Pascal ของ Linux มีสามรูปแบบ -

  • tar.gz เวอร์ชันพร้อมใช้งานเป็นไฟล์แยกต่างหาก

  • .rpm (Red Hat Package Manager) เวอร์ชัน

  • .deb (Debian) เวอร์ชัน

รหัสการติดตั้งสำหรับเวอร์ชัน. rpm ::

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

โดยที่ XYZ คือหมายเลขเวอร์ชันของไฟล์. rpm และ ARCH เป็นหนึ่งในสถาปัตยกรรมที่รองรับ (i386, x86_64 เป็นต้น)

รหัสการติดตั้งสำหรับเวอร์ชัน Debian (เช่น Ubuntu) -

dpkg -i fpc-XXX.deb

โดย XXX คือหมายเลขเวอร์ชันของไฟล์. deb

สำหรับรายละเอียดอ่าน: คู่มือการติดตั้ง Pascal ฟรี

การติดตั้ง Free Pascal บน Mac

หากคุณใช้ Mac OS X วิธีที่ง่ายที่สุดในการใช้ Free Pascal คือดาวน์โหลดสภาพแวดล้อมการพัฒนา Xcode จากเว็บไซต์ของ Apple และทำตามคำแนะนำในการติดตั้งอย่างง่าย เมื่อคุณตั้งค่า Xcode แล้วคุณจะสามารถใช้คอมไพเลอร์ Free Pascal ได้

การติดตั้ง Free Pascal บน Windows

สำหรับ Windows คุณจะดาวน์โหลดตัวติดตั้ง Windows setup.exe นี่เป็นโปรแกรมติดตั้งตามปกติ คุณต้องทำตามขั้นตอนต่อไปนี้สำหรับการติดตั้ง -

  • เลือกไดเร็กทอรี

  • เลือกบางส่วนของแพ็คเกจที่คุณต้องการติดตั้ง

  • เลือกที่จะเชื่อมโยงส่วนขยาย. ppp หรือ. pas กับ Free Pascal IDE

สำหรับรายละเอียดอ่าน: คู่มือการติดตั้ง Pascal ฟรี

แก้ไขข้อความ

สิ่งนี้จะใช้ในการพิมพ์โปรแกรมของคุณ ตัวอย่างของตัวแก้ไขบางตัว ได้แก่ Windows Notepad, OS Edit command, Brief, Epsilon, EMACS และ vim หรือ vi

ชื่อและเวอร์ชันของโปรแกรมแก้ไขข้อความอาจแตกต่างกันไปตามระบบปฏิบัติการต่างๆ ตัวอย่างเช่น Notepad จะใช้กับ Windows และสามารถใช้ vim หรือ vi บน windows ได้เช่นเดียวกับ Linux หรือ UNIX

ไฟล์ที่คุณสร้างด้วยโปรแกรมแก้ไขเรียกว่าไฟล์ต้นฉบับและมีซอร์สโค้ดของโปรแกรม ไฟล์ต้นฉบับสำหรับโปรแกรม Pascal มักจะตั้งชื่อด้วยนามสกุล.pas.

ก่อนเริ่มการเขียนโปรแกรมตรวจสอบให้แน่ใจว่าคุณมีโปรแกรมแก้ไขข้อความหนึ่งตัวและคุณมีประสบการณ์เพียงพอในการเขียนโปรแกรมคอมพิวเตอร์บันทึกลงในไฟล์รวบรวมและดำเนินการในที่สุด

ก่อนที่เราจะศึกษาโครงสร้างพื้นฐานของภาษาโปรแกรม Pascal ให้เราดูโครงสร้างโปรแกรม Pascal ขั้นต่ำที่เปลือยเปล่าเพื่อที่เราจะได้ใช้อ้างอิงในบทต่อ ๆ ไป

โครงสร้างโปรแกรมภาษาปาสคาล

โดยทั่วไปโปรแกรม Pascal ประกอบด้วยส่วนต่างๆดังต่อไปนี้ -

  • ชื่อโปรแกรม
  • ใช้คำสั่ง
  • พิมพ์ประกาศ
  • การประกาศคงที่
  • การประกาศตัวแปร
  • การประกาศฟังก์ชัน
  • การประกาศขั้นตอน
  • บล็อกโปรแกรมหลัก
  • คำสั่งและนิพจน์ภายในแต่ละบล็อก
  • Comments

โดยทั่วไปทุกโปรแกรมปาสคาลจะมีคำสั่งหัวเรื่องคำประกาศและส่วนการดำเนินการตามลำดับนั้นอย่างเคร่งครัด รูปแบบต่อไปนี้แสดงไวยากรณ์พื้นฐานสำหรับโปรแกรม Pascal -

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 }

ตัวอย่าง Pascal Hello World

ต่อไปนี้เป็นรหัสปาสคาลง่ายๆที่จะพิมพ์คำว่า "Hello, World!" -

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!');ใช้ฟังก์ชัน wreln ที่มีอยู่ในภาษาปาสคาลซึ่งทำให้เกิดข้อความ "Hello, World!" ที่จะแสดงบนหน้าจอ

  • คำสั่ง readkey;อนุญาตให้การแสดงผลหยุดชั่วคราวจนกว่าผู้ใช้จะกดปุ่ม มันเป็นส่วนหนึ่งของหน่วย crt หน่วยเป็นเหมือนห้องสมุดในภาษาปาสคาล

  • คำสั่งสุดท้าย end. สิ้นสุดโปรแกรมของคุณ

คอมไพล์และดำเนินการโปรแกรม Pascal

  • เปิดโปรแกรมแก้ไขข้อความและเพิ่มรหัสดังกล่าวข้างต้น

  • บันทึกไฟล์เป็นhello.pas

  • เปิดพรอมต์คำสั่งและไปที่ไดเร็กทอรีที่คุณบันทึกไฟล์

  • พิมพ์ fpc hello.pas ที่ command prompt แล้วกด Enter เพื่อคอมไพล์โค้ดของคุณ

  • หากรหัสของคุณไม่มีข้อผิดพลาดพรอมต์คำสั่งจะนำคุณไปยังบรรทัดถัดไปและจะสร้าง hello ไฟล์ปฏิบัติการและ hello.o ไฟล์ออบเจ็กต์

  • ตอนนี้พิมพ์ hello ที่พร้อมรับคำสั่งเพื่อดำเนินการโปรแกรมของคุณ

  • คุณจะสามารถเห็น "Hello World" พิมพ์อยู่บนหน้าจอและโปรแกรมจะรอจนกว่าคุณจะกดปุ่มใด ๆ

$ 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!

ตรวจสอบให้แน่ใจว่าคอมไพเลอร์ pascal ฟรี fpc อยู่ในเส้นทางของคุณและคุณกำลังเรียกใช้ในไดเร็กทอรีที่มีไฟล์ต้นฉบับ hello.pas

คุณได้เห็นโครงสร้างพื้นฐานของโปรแกรมปาสคาลแล้วดังนั้นจึงง่ายต่อการเข้าใจส่วนประกอบพื้นฐานอื่น ๆ ของภาษาโปรแกรมปาสคาล

ตัวแปร

นิยามตัวแปรถูกใส่ไว้ในบล็อกที่ขึ้นต้นด้วย var คำสำคัญตามด้วยคำจำกัดความของตัวแปรดังนี้:

var
A_Variable, B_Variable ... : Variable_Type;

ตัวแปรภาษาปาสคาลถูกประกาศนอกโค้ด - เนื้อความของฟังก์ชันซึ่งหมายความว่าตัวแปรเหล่านี้ไม่ได้ถูกประกาศภายในไฟล์ begin และ end คู่ แต่จะประกาศตามนิยามของขั้นตอน / ฟังก์ชันและก่อนหน้า beginคำสำคัญ. สำหรับตัวแปรส่วนกลางจะกำหนดไว้หลังส่วนหัวของโปรแกรม

หน้าที่ / ขั้นตอน

ในภาษาปาสคาลก procedure เป็นชุดคำสั่งที่จะดำเนินการโดยไม่มีค่าส่งคืนและ a 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, จริง, เริ่มต้น, อ่านไลน์, ไรท์ไลน์และสิ้นสุดเป็นคำสงวนทั้งหมด

ต่อไปนี้เป็นรายการคำสงวนที่มีอยู่ในภาษาปาสคาล

และ อาร์เรย์ เริ่ม กรณี const
div ทำ ลงไป อื่น จบ
ไฟล์ สำหรับ ฟังก์ชัน ไปที่ ถ้า
ใน ฉลาก mod ศูนย์ ไม่
ของ หรือ บรรจุ ขั้นตอน โปรแกรม
บันทึก ทำซ้ำ ชุด แล้ว ถึง
ชนิด จนถึง หลากหลาย ในขณะที่ ด้วย

ชุดอักขระและตัวระบุในภาษาปาสคาล

ชุดอักขระภาษาปาสคาลประกอบด้วย -

  • อักษรตัวพิมพ์ใหญ่ทั้งหมด (AZ)

  • อักษรตัวพิมพ์เล็กทั้งหมด (az)

  • ตัวเลขทั้งหมด (0-9)

  • สัญลักษณ์พิเศษ - + * /: =,. ;. () [] = {} `ช่องว่าง

เอนทิตีในโปรแกรม Pascal เช่นตัวแปรและค่าคงที่ประเภทฟังก์ชันโพรซีเดอร์และเร็กคอร์ด ฯลฯ มีชื่อหรือตัวระบุ ตัวระบุคือลำดับของตัวอักษรและตัวเลขโดยขึ้นต้นด้วยตัวอักษร ห้ามใช้สัญลักษณ์พิเศษและช่องว่างในตัวระบุ

ชนิดข้อมูลของเอนทิตีระบุความหมายข้อ จำกัด ค่าที่เป็นไปได้การดำเนินการฟังก์ชันและโหมดการจัดเก็บที่เกี่ยวข้อง

ชนิดจำนวนเต็มจริงบูลีนและอักขระเรียกว่าชนิดข้อมูลมาตรฐาน ประเภทข้อมูลสามารถแบ่งเป็นประเภทข้อมูลสเกลาร์ตัวชี้และโครงสร้าง ตัวอย่างประเภทข้อมูลสเกลาร์ ได้แก่ จำนวนเต็มจริงบูลีนอักขระช่วงย่อยและแจกแจง ประเภทข้อมูลที่มีโครงสร้างสร้างขึ้นจากประเภทสเกลาร์ ตัวอย่างเช่นอาร์เรย์ระเบียนไฟล์และชุด เราจะพูดถึงชนิดข้อมูลตัวชี้ในภายหลัง

ประเภทข้อมูล Pascal

ประเภทข้อมูล Pascal สามารถสรุปได้ดังต่อไปนี้ในแผนภาพต่อไปนี้ -

พิมพ์ Declarations

การประกาศประเภทใช้เพื่อประกาศประเภทข้อมูลของตัวระบุ ไวยากรณ์ของการประกาศประเภทคือ -

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

ตัวอย่างเช่นการประกาศต่อไปนี้กำหนดตัวแปรวันและอายุเป็นประเภทจำนวนเต็มใช่และจริงเป็นประเภทบูลีนชื่อและเมืองเป็นประเภทสตริงค่าธรรมเนียมและค่าใช้จ่ายเป็นประเภทจริง

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

ประเภทจำนวนเต็ม

ตารางต่อไปนี้ให้รายละเอียดเกี่ยวกับประเภทจำนวนเต็มมาตรฐานพร้อมขนาดพื้นที่จัดเก็บและช่วงค่าที่ใช้ใน Object Pascal -

ประเภท ขั้นต่ำ ขีดสุด รูปแบบ
จำนวนเต็ม -2147483648 2147483647 เซ็นชื่อ 32 บิต
พระคาร์ดินัล 0 4294967295 32 บิตที่ไม่ได้ลงชื่อ
Shortint -128 127 ลงนาม 8 บิต
Smallint -32768 32767 ลงนาม 16 บิต
Longint -2147483648 2147483647 เซ็นชื่อ 32 บิต
Int64 -2 ^ 63 2 ^ 63 - 1 เซ็นชื่อ 64 บิต
ไบต์ 0 255 8 บิตที่ไม่ได้ลงนาม
คำ 0 65535 16 บิตที่ไม่ได้ลงนาม
คำยาว 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ดังนั้นตัวพิมพ์ใหญ่และตัวพิมพ์เล็กจึงมีความหมายเหมือนกันที่นี่ ตามประเภทพื้นฐานที่อธิบายไว้ในบทที่แล้วจะมีประเภทตัวแปรพื้นฐานดังต่อไปนี้ -

ตัวแปรพื้นฐานในภาษาปาสคาล

ซีเนียร์ No ประเภทและคำอธิบาย
1

Character

โดยทั่วไปเป็นอ็อกเต็ตเดี่ยว (หนึ่งไบต์) นี่คือประเภทจำนวนเต็ม

2

Integer

ขนาดของจำนวนเต็มที่เป็นธรรมชาติที่สุดสำหรับเครื่อง

3

Real

ค่าทศนิยมที่มีความแม่นยำเดียว

4

Boolean

ระบุค่าตรรกะจริงหรือเท็จ นอกจากนี้ยังเป็นประเภทจำนวนเต็ม

5

Enumerated

ระบุรายการที่ผู้ใช้กำหนดเอง

6

Subrange

แสดงถึงตัวแปรที่มีค่าอยู่ในช่วง

7

String

เก็บอาร์เรย์ของอักขระ

ภาษาโปรแกรม Pascal ยังช่วยให้สามารถกำหนดตัวแปรประเภทอื่น ๆ ได้อีกด้วยซึ่งเราจะกล่าวถึงในบทต่อ ๆ ไปเช่น Pointer, Array, Records, Sets และ Files เป็นต้นสำหรับบทนี้ให้เราศึกษาเฉพาะตัวแปรพื้นฐานเท่านั้น

การประกาศตัวแปรในภาษาปาสคาล

ต้องประกาศตัวแปรทั้งหมดก่อนที่เราจะใช้ในโปรแกรม Pascal การประกาศตัวแปรทั้งหมดตามด้วยคีย์เวิร์ดvar การประกาศระบุรายการตัวแปรตามด้วยเครื่องหมายจุดคู่ (:) และประเภท ไวยากรณ์ของการประกาศตัวแปรคือ -

var
variable_list : type;

ในที่นี้ประเภทต้องเป็นชนิดข้อมูล Pascal ที่ถูกต้องซึ่งรวมถึงอักขระจำนวนเต็มจริงบูลีนหรือประเภทข้อมูลที่ผู้ใช้กำหนดเป็นต้นและ variable_list อาจประกอบด้วยชื่อตัวระบุอย่างน้อยหนึ่งชื่อโดยคั่นด้วยเครื่องหมายจุลภาค การประกาศตัวแปรที่ถูกต้องแสดงไว้ที่นี่ -

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ใน C ที่สำคัญที่สุดคือชื่อตัวแปรหมายถึงตำแหน่งหน่วยความจำที่จะจัดเก็บค่าของตัวแปร สิ่งนี้ไม่เป็นเช่นนั้นกับการประกาศประเภท

การเริ่มต้นตัวแปรในภาษาปาสคาล

ตัวแปรจะถูกกำหนดค่าด้วยเครื่องหมายจุดคู่และเครื่องหมายเท่ากับตามด้วยนิพจน์คงที่ รูปแบบทั่วไปของการกำหนดค่าคือ -

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

ค่าคงที่คือเอนทิตีที่ยังคงไม่เปลี่ยนแปลงระหว่างการทำงานของโปรแกรม ภาษาปาสคาลอนุญาตให้ประกาศเฉพาะค่าคงที่ประเภทต่อไปนี้ -

  • ประเภทลำดับ
  • กำหนดประเภท
  • ประเภทตัวชี้ (แต่ค่าเดียวที่อนุญาตคือ Nil)
  • ประเภทจริง
  • Char
  • String

การประกาศค่าคงที่

ไวยากรณ์สำหรับการประกาศค่าคงที่มีดังนี้ -

const
identifier = constant_value;

ตารางต่อไปนี้เป็นตัวอย่างของการประกาศค่าคงที่ที่ถูกต้อง -

Real type constant

ซีเนียร์ No ประเภทและตัวอย่างคงที่
1

Ordinal(Integer)type constant

valid_age = 21;

2

Set type constant

สระ = ชุดของ (A, E, I, O, U);

3

Pointer type constant

P = ไม่มี;

4

จ = 2.7182818;

velocity_light = 3.0E + 10;

5

Character type constant

ตัวดำเนินการ = '+';

6

String type constant

ประธาน = 'Johnny Depp';

ตัวอย่างต่อไปนี้แสดงแนวคิด -

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 หลักหลังเครื่องหมายทศนิยม ภาษาปาสคาลอนุญาตให้จัดรูปแบบเอาต์พุตดังกล่าวด้วยตัวแปรตัวเลข

ตัวดำเนินการคือสัญลักษณ์ที่บอกให้คอมไพเลอร์ดำเนินการจัดการทางคณิตศาสตร์หรือตรรกะเฉพาะ Pascal อนุญาตให้ใช้ตัวดำเนินการประเภทต่อไปนี้ -

  • ตัวดำเนินการเลขคณิต
  • ตัวดำเนินการเชิงสัมพันธ์
  • ตัวดำเนินการบูลีน
  • ตัวดำเนินการบิต
  • ตั้งค่าตัวดำเนินการ
  • ตัวดำเนินการสตริง

ให้เราพิจารณาตัวดำเนินการทางคณิตศาสตร์เชิงสัมพันธ์บูลีนและบิตทีละตัว เราจะพูดถึงตัวดำเนินการชุดและการทำงานของสตริงในภายหลัง

ตัวดำเนินการเลขคณิต

ตารางต่อไปนี้แสดงตัวดำเนินการเลขคณิตทั้งหมดที่ปาสคาลรองรับ สมมติตัวแปรA ถือ 10 และตัวแปร B ถือ 20 แล้ว -

แสดงตัวอย่าง

ตัวดำเนินการ คำอธิบาย ตัวอย่าง
+ เพิ่มสองตัวถูกดำเนินการ A + B จะให้ 30
- ลบตัวถูกดำเนินการที่สองจากตัวแรก A - B จะให้ -10
* คูณตัวถูกดำเนินการทั้งสอง A * B จะให้ 200
/ หารตัวเศษด้วยตัวส่วน B / A จะให้ 2
% ตัวดำเนินการโมดูลัสและส่วนที่เหลือหลังจากการหารจำนวนเต็ม B% A จะให้ 0

ตัวดำเนินการเชิงสัมพันธ์

ตารางต่อไปนี้แสดงตัวดำเนินการเชิงสัมพันธ์ทั้งหมดที่สนับสนุนโดย Pascal สมมติตัวแปรA ถือ 10 และตัวแปร B ถือ 20 แล้ว -

แสดงตัวอย่าง

ตัวดำเนินการ คำอธิบาย ตัวอย่าง
= ตรวจสอบว่าค่าของตัวถูกดำเนินการสองค่าเท่ากันหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง (A = B) ไม่เป็นความจริง
<> ตรวจสอบว่าค่าของตัวถูกดำเนินการสองค่าเท่ากันหรือไม่หากค่าไม่เท่ากันเงื่อนไขจะกลายเป็นจริง (A <> B) เป็นจริง
> ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายมากกว่าค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง (A> B) ไม่เป็นความจริง
< ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายน้อยกว่าค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง (A <B) เป็นจริง
> = ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายมากกว่าหรือเท่ากับค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง (A> = B) ไม่เป็นความจริง
<= ตรวจสอบว่าค่าของตัวถูกดำเนินการด้านซ้ายน้อยกว่าหรือเท่ากับค่าของตัวถูกดำเนินการด้านขวาหรือไม่ถ้าใช่เงื่อนไขจะกลายเป็นจริง (A <= B) เป็นจริง

ตัวดำเนินการบูลีน

ตารางต่อไปนี้แสดงตัวดำเนินการบูลีนทั้งหมดที่ภาษาปาสคาลรองรับ ตัวดำเนินการทั้งหมดนี้ทำงานบนตัวถูกดำเนินการบูลีนและสร้างผลลัพธ์แบบบูลีน สมมติตัวแปรA ถือเป็นจริงและตัวแปร B ถือเท็จแล้ว -

แสดงตัวอย่าง

ตัวดำเนินการ คำอธิบาย ตัวอย่าง
และ เรียกว่าตัวดำเนินการบูลีน AND หากตัวถูกดำเนินการทั้งสองเป็นจริงเงื่อนไขจะกลายเป็นจริง (A และ B) เป็นเท็จ
แล้ว มันคล้ายกับตัวดำเนินการ AND อย่างไรก็ตามมันรับประกันลำดับที่คอมไพลเลอร์ประเมินนิพจน์ตรรกะ จากซ้ายไปขวาและตัวถูกดำเนินการด้านขวาจะได้รับการประเมินเมื่อจำเป็นเท่านั้น (A และ B) เป็นเท็จ
หรือ เรียกว่า Boolean OR Operator ถ้าตัวถูกดำเนินการสองตัวใดตัวหนึ่งเป็นจริงเงื่อนไขจะกลายเป็นจริง (A หรือ B) เป็นจริง
หรืออื่น ๆ มันคล้ายกับ Boolean OR อย่างไรก็ตามจะรับประกันลำดับที่คอมไพลเลอร์ประเมินนิพจน์เชิงตรรกะ จากซ้ายไปขวาและตัวถูกดำเนินการด้านขวาจะได้รับการประเมินเมื่อจำเป็นเท่านั้น (A หรืออื่น ๆ B) เป็นจริง
ไม่ เรียกว่า Boolean NOT Operator ใช้เพื่อย้อนกลับสถานะตรรกะของตัวถูกดำเนินการ หากเงื่อนไขเป็นจริงตัวดำเนินการ Logical NOT จะทำให้เป็นเท็จ ไม่ (A และ B) เป็นจริง

ตัวดำเนินการบิต

ตัวดำเนินการ Bitwise ทำงานบนบิตและดำเนินการแบบบิตต่อบิต ตัวดำเนินการทั้งหมดเหล่านี้ทำงานกับตัวถูกดำเนินการจำนวนเต็มและสร้างผลลัพธ์จำนวนเต็ม ตารางความจริงสำหรับ bitwise และ (&), bitwise หรือ (|) และ bitwise not (~) มีดังนี้ -

q p & q p | q ~ น ~ q
0 0 0 0 1 1
0 1 0 1 1 0
1 1 1 1 0 0
1 0 0 1 0 1

สมมติว่า A = 60; และ B = 13; ตอนนี้ในรูปแบบไบนารีพวกเขาจะเป็นดังนี้ -

A = 0011 1100

B = 0000 1101

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

A&B = 0000 1100

ก ^ B = 0011 0001

~ A = 1100 0011

ตัวดำเนินการ Bitwise ที่สนับสนุนโดย Pascal แสดงอยู่ในตารางต่อไปนี้ สมมติว่าตัวแปร A ถือ 60 และตัวแปร B ถือ 13 จากนั้น:

แสดงตัวอย่าง

ตัวดำเนินการ คำอธิบาย ตัวอย่าง
& ไบนารี AND Operator จะคัดลอกบิตไปยังผลลัพธ์หากมีอยู่ในตัวถูกดำเนินการทั้งสอง (A & B) จะให้ 12 ซึ่งก็คือ 0000 1100
| ไบนารีหรือตัวดำเนินการจะคัดลอกบิตหากมีอยู่ในตัวถูกดำเนินการอย่างใดอย่างหนึ่ง (A | B) จะให้ 61 ซึ่งก็คือ 0011 1101
! ไบนารีหรือตัวดำเนินการจะคัดลอกบิตหากมีอยู่ในตัวถูกดำเนินการอย่างใดอย่างหนึ่ง เหมือนกับ | ตัวดำเนินการ (A! B) จะให้ 61 ซึ่งก็คือ 0011 1101
~ Binary Ones Complement Operator เป็นเอกภาพและมีผลของบิต 'พลิก' (~ A) จะให้ -61 ซึ่งก็คือ 1100 0011 ในรูปแบบส่วนเสริมของ 2 เนื่องจากเลขฐานสองที่ลงนาม
<< ตัวดำเนินการกะซ้ายแบบไบนารี ค่าตัวถูกดำเนินการด้านซ้ายจะถูกย้ายไปทางซ้ายตามจำนวนบิตที่ระบุโดยตัวถูกดำเนินการด้านขวา A << 2 จะให้ 240 ซึ่งก็คือ 1111 0000
>> ตัวดำเนินการกะไบนารีขวา ค่าตัวถูกดำเนินการด้านซ้ายจะถูกย้ายไปทางขวาตามจำนวนบิตที่ระบุโดยตัวถูกดำเนินการด้านขวา A >> 2 จะให้ 15 ซึ่งก็คือ 0000 1111

โปรดทราบว่าการใช้งาน Pascal ต่างกันในตัวดำเนินการแบบบิต Pascal ฟรีคอมไพเลอร์ที่เราใช้ที่นี่รองรับตัวดำเนินการบิตต่อไปนี้ -

ตัวดำเนินการ การดำเนินงาน
ไม่ ไม่ Bitwise
และ Bitwise AND
หรือ Bitwise หรือ
xor Bitwise เอกสิทธิ์หรือ
shl เลื่อนไปทางซ้าย
shr Bitwise เลื่อนไปทางขวา
<< เลื่อนไปทางซ้าย
>> Bitwise เลื่อนไปทางขวา

ลำดับความสำคัญของตัวดำเนินการในภาษาปาสคาล

ลำดับความสำคัญของตัวดำเนินการกำหนดการจัดกลุ่มคำศัพท์ในนิพจน์ สิ่งนี้มีผลต่อวิธีการประเมินนิพจน์ ตัวดำเนินการบางอย่างมีลำดับความสำคัญสูงกว่าผู้อื่น ตัวอย่างเช่นตัวดำเนินการคูณมีลำดับความสำคัญสูงกว่าตัวดำเนินการบวก

ตัวอย่างเช่น x = 7 + 3 * 2; ที่นี่ x ถูกกำหนดให้เป็น 13 ไม่ใช่ 20 เนื่องจากตัวดำเนินการ * มีลำดับความสำคัญสูงกว่า + ดังนั้นจึงได้รับการคูณด้วย 3 * 2 ก่อนแล้วจึงเพิ่มเป็น 7

ที่นี่ตัวดำเนินการที่มีลำดับความสำคัญสูงสุดจะปรากฏที่ด้านบนสุดของตารางตัวดำเนินการที่มีค่าต่ำสุดจะปรากฏที่ด้านล่าง ภายในนิพจน์ตัวดำเนินการที่มีลำดับความสำคัญสูงกว่าจะได้รับการประเมินก่อน

แสดงตัวอย่าง

ตัวดำเนินการ ลำดับความสำคัญ
~ ไม่ใช่ สูงสุด
*, /, div, mod และ, &
|,!, +, -, หรือ,
=, <>, <, <=,>,> =, ใน
หรืออื่น ๆ แล้ว ต่ำสุด

โครงสร้างการตัดสินใจกำหนดให้โปรแกรมเมอร์ระบุเงื่อนไขอย่างน้อยหนึ่งเงื่อนไขที่จะประเมินหรือทดสอบโดยโปรแกรมพร้อมกับคำสั่งหรือคำสั่งที่จะดำเนินการหากเงื่อนไขถูกกำหนดให้เป็นจริงและเป็นทางเลือกที่จะดำเนินการคำสั่งอื่น ๆ หากเงื่อนไข ถูกกำหนดให้เป็นเท็จ

ต่อไปนี้เป็นรูปแบบทั่วไปของโครงสร้างการตัดสินใจทั่วไปที่พบในภาษาโปรแกรมส่วนใหญ่ -

ภาษาการเขียนโปรแกรมภาษาปาสคาลมีข้อความประกอบการตัดสินใจประเภทต่อไปนี้ คลิกลิงก์ต่อไปนี้เพื่อตรวจสอบรายละเอียด

ซีเนียร์ No คำชี้แจงและคำอธิบาย
1 ถ้า - แล้วคำสั่ง

อัน if - then statement ประกอบด้วยนิพจน์บูลีนตามด้วยหนึ่งคำสั่งขึ้นไป

2 คำสั่ง if-then-else

อัน if - then statement ตามด้วยตัวเลือกก็ได้ else statementซึ่งดำเนินการเมื่อนิพจน์บูลีนเป็นเท็จ

3 คำสั่ง if ซ้อนกัน

คุณสามารถใช้ if หรือ else if คำสั่งภายในอื่น if หรือ else if คำสั่ง (s)

4 คำชี้แจงกรณี

case คำสั่งอนุญาตให้ทดสอบตัวแปรเพื่อความเท่าเทียมกับรายการค่า

5 กรณี - คำสั่งอื่น

มันคล้ายกับไฟล์ if-then-else คำให้การ. นี่คือไฟล์else ระยะตาม case statement.

6 คำสั่งกรณีที่ซ้อนกัน

คุณสามารถใช้ case คำสั่งภายในอื่น case คำสั่ง (s)

อาจมีสถานการณ์เมื่อคุณต้องดำเนินการบล็อกรหัสหลาย ๆ ครั้ง โดยทั่วไปคำสั่งจะดำเนินการตามลำดับ: คำสั่งแรกในฟังก์ชันจะถูกเรียกใช้งานก่อนตามด้วยคำสั่งที่สองและอื่น ๆ

ภาษาโปรแกรมจัดเตรียมโครงสร้างการควบคุมต่างๆที่ช่วยให้เส้นทางการดำเนินการซับซ้อนมากขึ้น

คำสั่งวนซ้ำช่วยให้เราดำเนินการคำสั่งหรือกลุ่มของคำสั่งได้หลายครั้งและต่อไปนี้เป็นรูปแบบทั่วไปของคำสั่งลูปในภาษาโปรแกรมส่วนใหญ่ -

ภาษาโปรแกรมปาสคาลจัดเตรียมโครงสร้างลูปประเภทต่อไปนี้เพื่อจัดการกับข้อกำหนดการวนซ้ำ คลิกลิงก์ต่อไปนี้เพื่อตรวจสอบรายละเอียด

ซีเนียร์ No ประเภทห่วงและคำอธิบาย
1 ลูป while-do

ทำซ้ำคำสั่งหรือกลุ่มของคำสั่งในขณะที่เงื่อนไขที่กำหนดเป็นจริง จะทดสอบเงื่อนไขก่อนที่จะดำเนินการร่างกายลูป

2 ห่วงสำหรับทำ

เรียกใช้ลำดับของคำสั่งหลาย ๆ ครั้งและย่อโค้ดที่จัดการตัวแปรลูป

3 วนซ้ำจนกว่า

เช่นเดียวกับคำสั่ง while ยกเว้นว่าจะทดสอบเงื่อนไขที่ส่วนท้ายของตัวห่วง

4 ลูปที่ซ้อนกัน

คุณสามารถใช้ลูปหนึ่งหรือหลายวงในอีกวงในขณะหนึ่งหรือทำซ้ำจนกว่าจะวนซ้ำ

คำสั่งควบคุมลูป

คำสั่งควบคุมแบบวนซ้ำเปลี่ยนการดำเนินการจากลำดับปกติ เมื่อการดำเนินการออกจากขอบเขตอ็อบเจ็กต์อัตโนมัติทั้งหมดที่สร้างขึ้นในขอบเขตนั้นจะถูกทำลาย

Pascal สนับสนุนคำสั่งควบคุมต่อไปนี้ คลิกลิงก์ต่อไปนี้เพื่อตรวจสอบรายละเอียด

ซีเนียร์ No คำชี้แจงและคำอธิบายการควบคุม
1 คำสั่งทำลาย

ยุติไฟล์ loop หรือ case คำสั่งและโอนการดำเนินการไปยังคำสั่งทันทีตามคำสั่ง loop หรือ case

2 ดำเนินการต่อ

ทำให้ลูปข้ามส่วนที่เหลือของร่างกายและทดสอบสภาพของมันใหม่ทันทีก่อนที่จะย้ำอีกครั้ง

3 คำสั่ง goto

การควบคุมการถ่ายโอนไปยังคำสั่งที่มีป้ายกำกับ แม้ว่าจะไม่แนะนำให้ใช้คำสั่ง goto ในโปรแกรมของคุณ

โปรแกรมย่อย

โปรแกรมย่อยคือหน่วยโปรแกรม / โมดูลที่ทำหน้าที่เฉพาะ โปรแกรมย่อยเหล่านี้จะรวมกันเพื่อสร้างโปรแกรมที่ใหญ่ขึ้น โดยทั่วไปเรียกว่า 'การออกแบบโมดูลาร์' โปรแกรมย่อยสามารถเรียกใช้โดยโปรแกรมย่อย / โปรแกรมซึ่งเรียกว่าโปรแกรมเรียก

Pascal มีโปรแกรมย่อยสองประเภท -

  • Functions - โปรแกรมย่อยเหล่านี้ส่งคืนค่าเดียว

  • Procedures - โปรแกรมย่อยเหล่านี้ไม่ส่งคืนค่าโดยตรง

ฟังก์ชั่น

functionคือกลุ่มของคำสั่งที่ทำงานร่วมกัน โปรแกรม Pascal ทุกโปรแกรมมีฟังก์ชันอย่างน้อยหนึ่งฟังก์ชันซึ่งก็คือโปรแกรมนั้นเองและโปรแกรมที่ไม่สำคัญที่สุดทั้งหมดสามารถกำหนดฟังก์ชันเพิ่มเติมได้

ฟังก์ชั่น declarationบอกคอมไพเลอร์เกี่ยวกับชื่อของฟังก์ชันชนิดการส่งคืนและพารามิเตอร์ ฟังก์ชั่นdefinition ให้ตัวจริงของฟังก์ชั่น

ไลบรารีมาตรฐาน Pascal มีฟังก์ชันในตัวมากมายที่โปรแกรมของคุณสามารถเรียกใช้ได้ ตัวอย่างเช่นฟังก์ชันAppendStr() ผนวกสองสตริงฟังก์ชัน New() จัดสรรหน่วยความจำแบบไดนามิกให้กับตัวแปรและฟังก์ชันอื่น ๆ อีกมากมาย

การกำหนดฟังก์ชัน

ในภาษาปาสคาลก functionถูกกำหนดโดยใช้คำสำคัญของฟังก์ชัน รูปแบบทั่วไปของนิยามฟังก์ชันมีดังนี้ -

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

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

นิยามฟังก์ชันในภาษาปาสคาลประกอบด้วยฟังก์ชัน header, ท้องถิ่น declarations และฟังก์ชั่น body. ส่วนหัวของฟังก์ชันประกอบด้วยฟังก์ชันคำสำคัญและไฟล์nameมอบให้กับฟังก์ชัน นี่คือส่วนทั้งหมดของฟังก์ชัน -

  • Arguments- อาร์กิวเมนต์สร้างความเชื่อมโยงระหว่างโปรแกรมเรียกและตัวระบุฟังก์ชันและเรียกอีกอย่างว่าพารามิเตอร์ที่เป็นทางการ พารามิเตอร์เปรียบเสมือนตัวยึดตำแหน่ง เมื่อเรียกใช้ฟังก์ชันคุณจะส่งค่าไปยังพารามิเตอร์ ค่านี้เรียกว่าพารามิเตอร์หรืออาร์กิวเมนต์จริง รายการพารามิเตอร์หมายถึงประเภทลำดับและจำนวนพารามิเตอร์ของฟังก์ชัน การใช้พารามิเตอร์ทางการดังกล่าวเป็นทางเลือก พารามิเตอร์เหล่านี้อาจมีประเภทข้อมูลมาตรฐานประเภทข้อมูลที่ผู้ใช้กำหนดเองหรือประเภทข้อมูลช่วงย่อย

    รายการพารามิเตอร์ที่เป็นทางการที่ปรากฏในคำสั่งฟังก์ชันอาจเป็นตัวแปรแบบธรรมดาหรือแบบห้อยลงอาร์เรย์หรือตัวแปรที่มีโครงสร้างหรือโปรแกรมย่อย

  • 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;

สำหรับฟังก์ชันที่กำหนดไว้ด้านบน max () ต่อไปนี้คือการประกาศฟังก์ชัน -

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

ต้องมีการประกาศฟังก์ชันเมื่อคุณกำหนดฟังก์ชันในไฟล์ต้นฉบับหนึ่งไฟล์และคุณเรียกใช้ฟังก์ชันนั้นในไฟล์อื่น ในกรณีนี้คุณควรประกาศฟังก์ชันที่ด้านบนของไฟล์ที่เรียกใช้ฟังก์ชัน

เรียกใช้ฟังก์ชัน

ในขณะที่สร้างฟังก์ชันคุณต้องให้คำจำกัดความว่าฟังก์ชันนั้นมีไว้ทำอะไร ในการใช้ฟังก์ชันคุณจะต้องเรียกใช้ฟังก์ชันนั้นเพื่อทำงานที่กำหนดไว้ เมื่อโปรแกรมเรียกใช้ฟังก์ชันการควบคุมโปรแกรมจะถูกโอนไปยังฟังก์ชันที่เรียก ฟังก์ชันที่เรียกว่าจะทำหน้าที่ที่กำหนดไว้และเมื่อคำสั่ง return ถูกดำเนินการหรือเมื่อถึงคำสั่งสุดท้ายสุดท้ายฟังก์ชันจะส่งคืนการควบคุมโปรแกรมกลับไปยังโปรแกรมหลัก

ในการเรียกใช้ฟังก์ชันคุณเพียงแค่ส่งพารามิเตอร์ที่ต้องการพร้อมกับชื่อฟังก์ชันและหากฟังก์ชันส่งคืนค่าคุณก็สามารถจัดเก็บค่าที่ส่งคืนได้ ต่อไปนี้เป็นตัวอย่างง่ายๆเพื่อแสดงการใช้งาน -

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 ตัวแปร 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 ของโปรแกรมย่อย

พารามิเตอร์ที่เป็นทางการจะทำงานเหมือนกับตัวแปรโลคัลอื่น ๆ ภายในโปรแกรมย่อยและถูกสร้างขึ้นเมื่อเข้าสู่โปรแกรมย่อยและถูกทำลายเมื่อออก

ในขณะที่เรียกโปรแกรมย่อยมีสองวิธีที่สามารถส่งผ่านอาร์กิวเมนต์ไปยังโปรแกรมย่อย -

ซีเนียร์ No ประเภทการโทรและคำอธิบาย
1 โทรตามค่า

วิธีนี้คัดลอกค่าที่แท้จริงของอาร์กิวเมนต์ลงในพารามิเตอร์ที่เป็นทางการของโปรแกรมย่อย ในกรณีนี้การเปลี่ยนแปลงที่เกิดขึ้นกับพารามิเตอร์ภายในโปรแกรมย่อยจะไม่มีผลกับอาร์กิวเมนต์

2 โทรตามข้อมูลอ้างอิง

วิธีนี้คัดลอกที่อยู่ของอาร์กิวเมนต์ลงในพารามิเตอร์ที่เป็นทางการ ภายในโปรแกรมย่อยจะใช้แอดเดรสเพื่อเข้าถึงอาร์กิวเมนต์จริงที่ใช้ในการโทร ซึ่งหมายความว่าการเปลี่ยนแปลงที่เกิดขึ้นกับพารามิเตอร์มีผลต่ออาร์กิวเมนต์

ตามค่าเริ่มต้น Pascal จะใช้ call by valueเพื่อส่งผ่านข้อโต้แย้ง โดยทั่วไปหมายความว่าโค้ดภายในโปรแกรมย่อยไม่สามารถเปลี่ยนแปลงอาร์กิวเมนต์ที่ใช้เรียกโปรแกรมย่อยได้ โปรแกรมตัวอย่างที่เราใช้ในบท 'Pascal - Functions' เรียกว่าฟังก์ชันชื่อ max () โดยใช้call by value.

ในขณะที่โปรแกรมตัวอย่างที่ให้ไว้ที่นี่ ( exProcedure ) เรียกขั้นตอน findMin () โดยใช้call by reference.

ขอบเขตในการเขียนโปรแกรมคือขอบเขตของโปรแกรมที่ตัวแปรที่กำหนดไว้สามารถมีอยู่ได้และไม่สามารถเข้าถึงตัวแปรนั้น มีสามตำแหน่งที่สามารถประกาศตัวแปรในภาษาโปรแกรม Pascal -

  • ภายในโปรแกรมย่อยหรือบล็อกซึ่งเรียกว่าตัวแปรท้องถิ่น

  • นอกโปรแกรมย่อยทั้งหมดซึ่งเรียกว่าตัวแปรส่วนกลาง

  • ในนิยามของพารามิเตอร์โปรแกรมย่อยซึ่งเรียกว่าพารามิเตอร์ทางการ

ให้เราอธิบายว่าคืออะไร local และ global ตัวแปรและพารามิเตอร์ทางการ

ตัวแปรท้องถิ่น

ตัวแปรที่ประกาศภายในโปรแกรมย่อยหรือบล็อกเรียกว่าตัวแปรโลคัล สามารถใช้ได้โดยคำสั่งที่อยู่ภายในโปรแกรมย่อยหรือบล็อกโค้ดนั้นเท่านั้น ตัวแปรโลคัลไม่รู้จักกับโปรแกรมย่อยภายนอกโปรแกรมย่อย ต่อไปนี้เป็นตัวอย่างการใช้ตัวแปรท้องถิ่น นี่ตัวแปรทั้งหมด, BและCมีในท้องถิ่นในการเขียนโปรแกรมชื่อexLocal

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

ตอนนี้ให้เราขยายโปรแกรมอีกเล็กน้อยให้เราสร้างโพรซีเดอร์ที่ชื่อว่า display ซึ่งจะมีชุดของตัวแปรa , bและcและแสดงค่าจากโปรแกรมexLocalโดยตรง

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 ซึ่งเป็นตัวแปรส่วนกลางที่เกี่ยวข้องกับการแสดงผลเช่นเดียวกับตัวแปรโลคัลของมันเอง โปรแกรมสามารถมีชื่อเดียวกันสำหรับตัวแปรโลคัลและโกลบอล แต่ค่าของตัวแปรโลคัลภายในฟังก์ชันจะใช้ค่ากำหนด

ให้เราเปลี่ยนตัวอย่างก่อนหน้าเล็กน้อยตอนนี้ตัวแปรโลคัลสำหรับการแสดงโพรซีเดอร์มีชื่อเดียวกับ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

สตริงในภาษาปาสคาลเป็นลำดับของอักขระที่มีข้อกำหนดขนาดที่เป็นทางเลือก อักขระอาจเป็นตัวเลขตัวอักษรว่างอักขระพิเศษหรือรวมกันทั้งหมด Extended Pascal มีอ็อบเจ็กต์สตริงหลายประเภทขึ้นอยู่กับระบบและการนำไปใช้งาน เราจะพูดถึงประเภทของสตริงทั่วไปที่ใช้ในโปรแกรม

คุณสามารถกำหนดสตริงได้หลายวิธี -

  • Character arrays - นี่คือสตริงอักขระซึ่งเป็นลำดับของอักขระขนาดศูนย์หรือมากกว่าไบต์ที่อยู่ในเครื่องหมายคำพูดเดี่ยว

  • String variables - ตัวแปรประเภท String ตามที่กำหนดใน Turbo Pascal

  • Short strings - ตัวแปรประเภท String พร้อมข้อกำหนดขนาด

  • Null terminated strings - ตัวแปรของ pchar ประเภท.

  • AnsiStrings - Ansistrings คือสตริงที่ไม่จำกัดความยาว

Pascal มีตัวดำเนินการสตริงเพียงตัวเดียวคือตัวดำเนินการต่อสตริง (+)

ตัวอย่าง

โปรแกรมต่อไปนี้จะพิมพ์สตริงสี่ชนิดแรก เราจะใช้ 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

ฟังก์ชันและขั้นตอนปาสคาลสตริง

Pascal รองรับฟังก์ชันและโพรซีเดอร์ที่หลากหลายที่จัดการกับสตริง โปรแกรมย่อยเหล่านี้แตกต่างกันไปในการใช้งานที่ชาญฉลาด ที่นี่เราแสดงรายการสตริงต่างๆที่จัดการโปรแกรมย่อยที่จัดทำโดย Free Pascal -

ซีเนียร์ ฟังก์ชั่นและวัตถุประสงค์
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;

เปรียบเทียบอักขระ L ของสตริงที่คำนึงถึงขนาดตัวพิมพ์

10

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

เปรียบเทียบอักขระ L ของสตริงที่ไม่คำนึงถึงตัวพิมพ์เล็กและใหญ่

11

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;

คัดลอก N ไบต์ของสตริงปาสกาล

35

function UpperCase(const s:):;

แปลงสตริงเป็นตัวพิมพ์ใหญ่ทั้งหมด

Pascal จัดเตรียมประเภทข้อมูล Boolean ที่ช่วยให้โปรแกรมเมอร์สามารถกำหนดจัดเก็บและจัดการกับเอนทิตีตรรกะเช่นค่าคงที่ตัวแปรฟังก์ชันและนิพจน์เป็นต้น

ค่าบูลีนโดยพื้นฐานแล้วเป็นประเภทจำนวนเต็ม ตัวแปรประเภทบูลีนมีค่าที่เป็นไปได้ที่กำหนดไว้ล่วงหน้าสองค่าTrue และ False. นิพจน์ที่แก้ไขเป็นค่าบูลีนสามารถกำหนดให้กับชนิดบูลีนได้เช่นกัน

Pascal ฟรียังรองรับไฟล์ ByteBool, WordBool และ LongBoolประเภท เป็นประเภท Byte, Word หรือ Longint ตามลำดับ

ค่า False จะเทียบเท่ากับ 0 (ศูนย์) และค่าที่ไม่ใช่ศูนย์จะถือว่าเป็น True เมื่อแปลงเป็นค่าบูลีน ค่าบูลีนของ True จะถูกแปลงเป็น -1 ในกรณีที่กำหนดให้กับตัวแปรประเภท LongBool

ควรสังเกตว่าตัวดำเนินการเชิงตรรกะ and, or และ not ถูกกำหนดไว้สำหรับชนิดข้อมูลบูลีน

การประกาศประเภทข้อมูลบูลีน

ตัวแปรประเภทบูลีนถูกประกาศโดยใช้คีย์เวิร์ด var

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

ภาษาการเขียนโปรแกรมภาษาปาสคาลจัดเตรียมโครงสร้างข้อมูลที่เรียกว่าอาร์เรย์ซึ่งสามารถจัดเก็บคอลเลกชันตามลำดับที่มีขนาดคงที่ขององค์ประกอบประเภทเดียวกัน อาร์เรย์ใช้ในการจัดเก็บชุดข้อมูล แต่มักจะมีประโยชน์มากกว่าที่จะคิดว่าอาร์เรย์เป็นชุดของตัวแปรประเภทเดียวกัน

แทนที่จะประกาศตัวแปรแต่ละตัวเช่น number1, number2, ... และ number100 คุณจะประกาศตัวแปรอาร์เรย์หนึ่งตัวเช่นตัวเลขและใช้ตัวเลข [1], ตัวเลข [2] และ ... , ตัวเลข [100] เพื่อแสดง ตัวแปรแต่ละตัว องค์ประกอบเฉพาะในอาร์เรย์ถูกเข้าถึงโดยดัชนี

อาร์เรย์ทั้งหมดประกอบด้วยตำแหน่งหน่วยความจำที่อยู่ติดกัน ที่อยู่ต่ำสุดสอดคล้องกับองค์ประกอบแรกและที่อยู่สูงสุดขององค์ประกอบสุดท้าย

โปรดทราบว่าหากคุณต้องการอาร์เรย์สไตล์ C โดยเริ่มจากดัชนี 0 คุณต้องเริ่มดัชนีจาก 0 แทนที่จะเป็น 1

การประกาศอาร์เรย์

ในการประกาศอาร์เรย์ในภาษาปาสคาลโปรแกรมเมอร์อาจประกาศประเภทจากนั้นสร้างตัวแปรของอาร์เรย์นั้นหรือประกาศตัวแปรอาร์เรย์โดยตรง

รูปแบบทั่วไปของการประกาศประเภทของอาร์เรย์หนึ่งมิติคือ -

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;

ประเภทของ Array Subscript

ในภาษาปาสคาลตัวห้อยอาร์เรย์อาจเป็นประเภทสเกลาร์เช่นจำนวนเต็มบูลีนแจกแจงหรือช่วงย่อยยกเว้นจริง ตัวห้อยอาร์เรย์อาจมีค่าเป็นลบเช่นกัน

ตัวอย่างเช่น,

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;

Subscript อาจเป็นประเภทที่แจกแจง -

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

การเริ่มต้นอาร์เรย์

ในภาษาปาสคาลอาร์เรย์จะเริ่มต้นผ่านการกำหนดไม่ว่าจะโดยการระบุตัวห้อยเฉพาะหรือใช้ลูป for-do

ตัวอย่างเช่น -

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'];

คำสั่งข้างต้นจะนำองค์ประกอบแรกจากอาร์เรย์ที่ชื่อตัวอักษรและกำหนดค่าให้กับตัวแปร 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

Pascal Arrays ในรายละเอียด

อาร์เรย์มีความสำคัญต่อภาษาปาสคาลและควรมีรายละเอียดเพิ่มเติมมากมาย มีแนวคิดสำคัญบางประการที่เกี่ยวข้องกับอาร์เรย์ซึ่งควรชัดเจนสำหรับโปรแกรมเมอร์ปาสคาล -

ซีเนียร์ No แนวคิดและคำอธิบาย
1 อาร์เรย์หลายมิติ

Pascal รองรับอาร์เรย์หลายมิติ รูปแบบที่ง่ายที่สุดของอาร์เรย์หลายมิติคืออาร์เรย์สองมิติ

2 อาร์เรย์แบบไดนามิก

ในอาร์เรย์ประเภทนี้ความยาวเริ่มต้นคือศูนย์ ต้องกำหนดความยาวจริงของอาร์เรย์ด้วยมาตรฐานSetLength ฟังก์ชัน

3 อาร์เรย์ที่บรรจุ

อาร์เรย์เหล่านี้บรรจุบิตกล่าวคือแต่ละอักขระหรือค่าความจริงจะถูกเก็บไว้ในไบต์ต่อเนื่องกันแทนที่จะใช้หน่วยเก็บข้อมูลเดียว

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;

ตัวแปรพอยน์เตอร์จะถูกอ้างอิงโดยใช้สัญลักษณ์คาเร็ต (^) เดียวกัน ยกตัวอย่างเช่นตัวแปรที่เกี่ยวข้องเรียกโดยตัวชี้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 ได้ดังนี้ -

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

Pascal Pointers ในรายละเอียด

พอยน์เตอร์มีแนวคิดมากมาย แต่ใช้งานง่ายและมีความสำคัญต่อการเขียนโปรแกรมภาษาปาสคาล มีแนวคิดตัวชี้ที่สำคัญต่อไปนี้ซึ่งควรชัดเจนสำหรับโปรแกรมเมอร์ปาสคาล -

ซีเนียร์ No แนวคิดและคำอธิบาย
1 ปาสคาล - ตัวชี้เลขคณิต

มีตัวดำเนินการทางคณิตศาสตร์สี่ตัวที่สามารถใช้กับพอยน์เตอร์: เพิ่มขึ้น, ลดลง, +, -

2 Pascal - อาร์เรย์ของพอยน์เตอร์

คุณสามารถกำหนดอาร์เรย์เพื่อเก็บพอยน์เตอร์ได้หลายตัว

3 Pascal - ตัวชี้ไปยังตัวชี้

Pascal ช่วยให้คุณมีตัวชี้บนตัวชี้และอื่น ๆ

4 ส่งพอยน์เตอร์ไปยังโปรแกรมย่อยในภาษาปาสคาล

การส่งผ่านอาร์กิวเมนต์โดยการอ้างอิงหรือตามที่อยู่ทั้งสองทำให้อาร์กิวเมนต์ที่ส่งผ่านสามารถเปลี่ยนแปลงได้ในโปรแกรมย่อยการเรียกโดยโปรแกรมย่อยที่เรียกว่า

5 ส่งกลับตัวชี้จากโปรแกรมย่อยในภาษาปาสคาล

ภาษาปาสคาลอนุญาตให้โปรแกรมย่อยส่งกลับตัวชี้

อาร์เรย์ Pascal ช่วยให้คุณสามารถกำหนดประเภทของตัวแปรที่สามารถเก็บข้อมูลหลายรายการในประเภทเดียวกัน แต่ระเบียนเป็นประเภทข้อมูลที่ผู้ใช้กำหนดเองที่มีอยู่ใน Pascal ซึ่งช่วยให้คุณสามารถรวมรายการข้อมูลประเภทต่างๆได้

ระเบียนประกอบด้วยฟิลด์ต่างๆ สมมติว่าคุณต้องการติดตามหนังสือของคุณในห้องสมุดคุณอาจต้องการติดตามคุณลักษณะต่อไปนี้เกี่ยวกับหนังสือแต่ละเล่ม -

  • 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

ด้วยคำชี้แจง

เราได้หารือกันว่าสมาชิกของบันทึกสามารถเข้าถึงได้โดยใช้ตัวดำเนินการเข้าถึงสมาชิก (.) วิธีนี้จะต้องเขียนชื่อของตัวแปร record ทุกครั้ง 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;

Pascal รองรับหน่วยเก็บข้อมูลประเภทเฉพาะที่มีชื่อตัวแปร คุณสามารถกำหนดประเภทของค่าง่ายๆในตัวแปรตัวแปร ชนิดของค่าที่จัดเก็บในตัวแปรจะถูกกำหนดที่รันไทม์เท่านั้น สามารถกำหนดประเภทที่เรียบง่ายเกือบทุกประเภทให้กับตัวแปร: ประเภทลำดับ, ประเภทสตริง, ประเภท int64

ประเภทที่มีโครงสร้างเช่นชุดระเบียนอาร์เรย์ไฟล์ออบเจ็กต์และคลาสไม่สามารถใช้งานร่วมกับตัวแปรได้ คุณยังสามารถกำหนดตัวชี้ให้กับตัวแปรได้

Pascal ฟรีรองรับรูปแบบต่างๆ

การประกาศตัวแปร

คุณสามารถประกาศประเภทตัวแปรเช่นเดียวกับประเภทอื่น ๆ โดยใช้ไฟล์ varคำสำคัญ. ไวยากรณ์สำหรับการประกาศประเภทตัวแปรคือ -

var
   v: variant;

ตอนนี้ตัวแปรตัวแปร v นี้สามารถกำหนดให้กับประเภทง่าย ๆ เกือบทั้งหมดรวมถึงประเภทที่แจกแจงและในทางกลับกัน

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;

ตัวอย่าง

ตัวอย่างต่อไปนี้จะแสดงแนวคิด -

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.

เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -

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

ชุดคือชุดขององค์ประกอบประเภทเดียวกัน Pascal อนุญาตให้กำหนดชนิดข้อมูลชุด องค์ประกอบในชุดเรียกว่าสมาชิก ในทางคณิตศาสตร์ชุดโดยมีตัวแทนสมาชิกล้อมรอบภายในวงเล็บ {} อย่างไรก็ตามในภาษาปาสคาลองค์ประกอบชุดจะอยู่ภายในวงเล็บเหลี่ยม [] ซึ่งเรียกว่าตัวสร้างชุด

การกำหนดประเภทชุดและตัวแปร

ประเภทชุดปาสกาลถูกกำหนดเป็น

type
set-identifier = set of base type;

ตัวแปรของประเภทชุดถูกกำหนดเป็น

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

หรือ,

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

ตัวอย่างของการประกาศประเภทชุดที่ถูกต้อง ได้แก่ -

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;

ตั้งค่าตัวดำเนินการ

คุณสามารถดำเนินการชุดต่อไปนี้บนชุดปาสกาล

ซีเนียร์ No การดำเนินงานและคำอธิบาย
1

Union

สิ่งนี้รวมสองชุดและให้ชุดใหม่กับสมาชิกจากทั้งสองชุด

2

Difference

รับความแตกต่างของสองชุดและให้ชุดใหม่ที่มีองค์ประกอบที่ไม่เหมือนกันสำหรับชุดใดชุดหนึ่ง

3

Intersection

รับจุดตัดของสองชุดและให้ชุดใหม่ที่มีองค์ประกอบเหมือนกันกับทั้งสองชุด

4

Inclusion

ชุด P จะรวมอยู่ในชุด Q ถ้ารายการทั้งหมดใน P อยู่ใน Q ด้วย แต่ไม่ใช่ในทางกลับกัน

5

Symmetric difference

รับความแตกต่างแบบสมมาตรของสองชุดและให้ชุดขององค์ประกอบซึ่งอยู่ในชุดใดชุดหนึ่งและไม่อยู่ในจุดตัดกัน

6

In

จะตรวจสอบความเป็นสมาชิก

ตารางต่อไปนี้แสดงตัวดำเนินการชุดทั้งหมดที่สนับสนุนโดย Free Pascal สมมติว่าS1 และ S2 เป็นชุดอักขระสองชุดเช่นนั้น -

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

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

ตัวดำเนินการ คำอธิบาย ตัวอย่าง
+ สหภาพสองชุด

S1 + S2 จะให้ชุด

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

- ความแตกต่างของสองชุด

S1 - S2 จะให้ชุด

['a', 'b']

* จุดตัดของสองชุด

S1 * S2 จะให้ชุด

['ค']

> < ความแตกต่างแบบสมมาตรของสองชุด S1> <S2 จะให้ชุด ['a', 'b', 'd', 'e']
= ตรวจสอบความเท่าเทียมกันของสองชุด S1 = S2 จะให้ค่าบูลีนเป็นเท็จ
<> ตรวจสอบความไม่เท่ากันของสองชุด S1 <> S2 จะให้ค่าบูลีนเป็นจริง
<= ประกอบด้วย (ตรวจสอบว่าชุดหนึ่งเป็นชุดย่อยของชุดอื่น ๆ หรือไม่) S1 <= S2 จะให้ค่าบูลีน False
รวม รวมองค์ประกอบในชุด โดยพื้นฐานแล้วมันคือการรวมกันของเซตและองค์ประกอบของประเภทฐานเดียวกัน

รวม (S1, ['d']) จะให้ชุด

['เอบีซีดี']

ไม่รวม ไม่รวมองค์ประกอบจากชุด โดยพื้นฐานแล้วมันคือความแตกต่างของเซตและองค์ประกอบของประเภทฐานเดียวกัน

ไม่รวม (S2, ['d']) จะให้ชุด

['c', 'e']

ใน ตรวจสอบการตั้งค่าความเป็นสมาชิกขององค์ประกอบในชุด ['e'] ใน S2 ให้ค่าบูลีน True

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงให้เห็นถึงการใช้ตัวดำเนินการเหล่านี้ -

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.

เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -

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

Pascal ถือว่าไฟล์เป็นลำดับของส่วนประกอบซึ่งต้องเป็นประเภทเดียวกัน ประเภทของไฟล์ถูกกำหนดโดยประเภทของส่วนประกอบ ประเภทข้อมูลไฟล์ถูกกำหนดเป็น -

type
file-name = file of base-type;

โดยที่ประเภทฐานระบุประเภทของส่วนประกอบของไฟล์ ประเภทฐานอาจเป็นอะไรก็ได้เช่นจำนวนเต็มจริงบูลีนแจกแจงช่วงย่อยบันทึกอาร์เรย์และชุดยกเว้นไฟล์ประเภทอื่น ตัวแปรของประเภทไฟล์ถูกสร้างขึ้นโดยใช้การประกาศvar -

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;

การสร้างและเขียนลงไฟล์

ให้เราเขียนโปรแกรมที่จะสร้างไฟล์ข้อมูลสำหรับบันทึกของนักเรียน มันจะสร้างไฟล์ชื่อ 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');
   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ลงในไดเร็กทอรีการทำงาน คุณสามารถเปิดไฟล์โดยใช้โปรแกรมแก้ไขข้อความเช่น notepad เพื่อดูข้อมูลของ John Smith

อ่านจากไฟล์

เราเพิ่งสร้างและเขียนลงในไฟล์ชื่อ 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

ไฟล์เป็นพารามิเตอร์โปรแกรมย่อย

ภาษาปาสคาลอนุญาตให้ใช้ตัวแปรไฟล์เป็นพารามิเตอร์ในโปรแกรมย่อยมาตรฐานและโปรแกรมย่อยที่ผู้ใช้กำหนดเอง ตัวอย่างต่อไปนี้แสดงให้เห็นถึงแนวคิดนี้ โปรแกรมจะสร้างไฟล์ชื่อ rain.txt และเก็บข้อมูลปริมาณน้ำฝน จากนั้นจะเปิดไฟล์อ่านข้อมูลและคำนวณปริมาณน้ำฝนเฉลี่ย

โปรดทราบว่า 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

ฟังก์ชั่นการจัดการไฟล์

Free Pascal มีฟังก์ชัน / ขั้นตอนต่อไปนี้สำหรับการจัดการไฟล์ -

ซีเนียร์ ชื่อฟังก์ชันและคำอธิบาย
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);

กำหนดชื่อให้กับไฟล์

11

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;

ส่งคืนผลลัพธ์ของการดำเนินการ IO ของไฟล์สุดท้าย

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;

แต่ตอนนี้ให้เราพิจารณาสถานการณ์ที่คุณไม่ทราบเกี่ยวกับความยาวของข้อความที่คุณต้องการจัดเก็บตัวอย่างเช่นคุณต้องการจัดเก็บคำอธิบายโดยละเอียดเกี่ยวกับหัวข้อ ที่นี่เราจำเป็นต้องกำหนดตัวชี้ไปที่สตริงโดยไม่กำหนดจำนวนหน่วยความจำที่จำเป็น

Pascal มีขั้นตอน 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อนุญาตให้ระบุสิ่งนั้นได้ ให้เราเขียนตัวอย่างก่อนหน้านี้ใหม่โดยใช้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

ดังนั้นคุณจึงสามารถควบคุมได้อย่างสมบูรณ์และคุณสามารถส่งผ่านค่าขนาดใดก็ได้ในขณะที่จัดสรรหน่วยความจำซึ่งแตกต่างจากอาร์เรย์ซึ่งเมื่อคุณกำหนดขนาดแล้วจะไม่สามารถเปลี่ยนแปลงได้

การปรับขนาดและการปล่อยหน่วยความจำ

เมื่อโปรแกรมของคุณออกมาระบบปฏิบัติการจะปล่อยหน่วยความจำทั้งหมดที่โปรแกรมของคุณจัดสรรโดยอัตโนมัติ แต่เพื่อเป็นการปฏิบัติที่ดีเมื่อคุณไม่ต้องการหน่วยความจำอีกต่อไปคุณควรปล่อยหน่วยความจำนั้น

Pascal จัดเตรียมขั้นตอน dispose เพื่อปลดปล่อยตัวแปรที่สร้างขึ้นแบบไดนามิกโดยใช้โพรซีเดอร์ new. หากคุณจัดสรรหน่วยความจำโดยใช้ไฟล์ getmem โปรแกรมย่อยคุณต้องใช้โปรแกรมย่อย freememเพื่อเพิ่มหน่วยความจำนี้ FreeMemโปรแกรมย่อยมีไวยากรณ์ต่อไปนี้ -

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

ฟังก์ชั่นการจัดการหน่วยความจำ

Pascal จัดเตรียมฟังก์ชันการจัดการหน่วยความจำที่ใช้ในการปรับใช้โครงสร้างข้อมูลต่างๆและการใช้โปรแกรมระดับต่ำในภาษาปาสคาล หลายฟังก์ชันเหล่านี้ขึ้นอยู่กับการใช้งาน Free Pascal มีฟังก์ชันและขั้นตอนการจัดการหน่วยความจำดังต่อไปนี้ -

SN ชื่อฟังก์ชันและคำอธิบาย
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;

ส่งคืนส่วนข้อมูล

11

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;

ส่งคืนค่าทะเบียนเซ็กเมนต์สแต็ก

โปรแกรม Pascal สามารถประกอบด้วยโมดูลที่เรียกว่าหน่วย หน่วยอาจประกอบด้วยบล็อกโค้ดบางส่วนซึ่งประกอบด้วยตัวแปรและการประกาศประเภทคำสั่งขั้นตอน ฯลฯ มีหน่วยในตัวจำนวนมากในภาษาปาสคาลและปาสคาลช่วยให้โปรแกรมเมอร์กำหนดและเขียนหน่วยของตนเองเพื่อใช้ ในโปรแกรมต่างๆในภายหลัง

การใช้หน่วยในตัว

ทั้งหน่วยในตัวและหน่วยที่ผู้ใช้กำหนดจะรวมอยู่ในโปรแกรมโดยใช้ประโยคคำสั่ง เราได้ใช้หน่วยตัวแปรในบทช่วยสอนPascal - Variantsแล้ว บทช่วยสอนนี้อธิบายการสร้างและรวมหน่วยที่ผู้ใช้กำหนดเอง อย่างไรก็ตามก่อนอื่นให้เราดูวิธีรวมยูนิตในตัว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;

ต่อไปนี้เป็นขั้นตอนสำคัญสามขั้นตอนในการสร้างหน่วย Pascal -

  • ชื่อไฟล์และชื่อหน่วยควรตรงกันทุกประการ ดังนั้นหน่วยของเราคำนวณพื้นที่จะถูกบันทึกไว้ในไฟล์ที่ชื่อคำนวณArea.pas

  • บรรทัดถัดไปควรประกอบด้วยคำหลักคำเดียว interface. หลังจากบรรทัดนี้คุณจะต้องเขียนประกาศสำหรับฟังก์ชันและขั้นตอนทั้งหมดที่จะมาในหน่วยนี้

  • หลังจากประกาศฟังก์ชันแล้วให้เขียนคำ implementationซึ่งเป็นคำหลักอีกครั้ง หลังจากบรรทัดที่มีการใช้คีย์เวิร์ดให้ระบุคำจำกัดความของโปรแกรมย่อยทั้งหมด

โปรแกรมต่อไปนี้จะสร้างหน่วยที่ชื่อว่าคำนวณArea -

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

โปรแกรมส่วนใหญ่ที่คุณเขียนจำเป็นต้องใช้ฟังก์ชันวันที่บางรูปแบบที่ส่งคืนวันที่และเวลาปัจจุบัน วันที่เป็นส่วนหนึ่งของชีวิตประจำวันมากจนสามารถทำงานกับพวกเขาได้โดยไม่ต้องคิดอะไรเลย Pascal ยังมีเครื่องมือที่มีประสิทธิภาพสำหรับการคำนวณวันที่ซึ่งทำให้การจัดการวันที่เป็นเรื่องง่าย อย่างไรก็ตามชื่อจริงและการทำงานของฟังก์ชันเหล่านี้แตกต่างกันสำหรับคอมไพเลอร์ที่แตกต่างกัน

รับวันที่และเวลาปัจจุบัน

ฟังก์ชัน TimeToString ของ Pascal จะให้เวลาปัจจุบันในรูปแบบคั่นด้วยเครื่องหมายโคลอน (:) ตัวอย่างต่อไปนี้แสดงวิธีรับเวลาปัจจุบัน -

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

ฟังก์ชัน Now ส่งคืนวันที่และเวลาปัจจุบัน -

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:

Free Pascal มีโครงสร้างการประทับเวลาที่เรียบง่ายชื่อ TTimeStampซึ่งมีรูปแบบดังนี้ -

type TTimeStamp = record
   Time: Integer;
   Date: Integer;
end;

ฟังก์ชั่นวันที่และเวลาต่างๆ

Free Pascal มีฟังก์ชันวันที่และเวลาดังต่อไปนี้ -

ซีเนียร์ ชื่อฟังก์ชันและคำอธิบาย
1

function DateTimeToFileDate(DateTime: TDateTime):LongInt;

แปลงประเภท DateTime เป็นวันที่ของไฟล์

2

function DateTimeToStr( DateTime: TDateTime):;

สร้างการแสดงสตริงของ DateTime

3

function DateTimeToStr(DateTime: TDateTime; const FormatSettings: TFormatSettings):;

สร้างการแสดงสตริงของ DateTime

4

procedure DateTimeToString(out Result: ;const FormatStr: ;const DateTime: TDateTime);

สร้างการแสดงสตริงของ DateTime

5

procedure DateTimeToString(out Result: ; const FormatStr: ; const DateTime: TDateTime; const FormatSettings: TFormatSettings);

สร้างการแสดงสตริงของ DateTime

6

procedure DateTimeToSystemTime(DateTime: TDateTime; out SystemTime: TSystemTime);

แปลง DateTime เป็นเวลาของระบบ

7

function DateTimeToTimeStamp( DateTime: TDateTime):TTimeStamp;แปลง DateTime เป็น timestamp

8

function DateToStr(Date: TDateTime):;

สร้างการแสดงวันที่สตริง

9

function DateToStr(Date: TDateTime; const FormatSettings: TFormatSettings):;

สร้างการแสดงวันที่สตริง

10

function Date: TDateTime;

รับวันที่ปัจจุบัน

11

function DayOfWeek(DateTime: TDateTime):Integer;

รับวันในสัปดาห์

12

procedure DecodeDate(Date: TDateTime; out Year: Word; out Month: Word; out Day: Word);

ถอดรหัส DateTime เป็นปีเดือนและวัน

13

procedure DecodeTime(Time: TDateTime; out Hour: Word; out Minute: Word; out Second: Word; out MilliSecond: Word);

ถอดรหัส DateTime เป็นชั่วโมงนาทีและวินาที

14

function EncodeDate(Year: Word; Month: Word; Day: Word):TDateTime;

เข้ารหัสปีวันและเดือนเป็น DateTime

15

function EncodeTime(Hour: Word; Minute: Word; Second: Word; MilliSecond: Word):TDateTime;

เข้ารหัสชั่วโมงนาทีและวินาทีเป็น DateTime

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;

แปลงสตริงเป็น DateTime

23

function StrToDateTime(const s: ShortString; const FormatSettings: TFormatSettings):TDateTime;

แปลงสตริงเป็น DateTime

24

function StrToDateTime(const s: AnsiString; const FormatSettings: TFormatSettings):TDateTime;

แปลงสตริงเป็น DateTime

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;

แปลงการประทับเวลาเป็น DateTime

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- คลาสถูกกำหนดในลักษณะเดียวกับ Object แต่มีความแตกต่างในวิธีสร้าง คลาสได้รับการจัดสรรบน Heap ของโปรแกรมในขณะที่ Object ถูกจัดสรรบน Stack มันเป็นตัวชี้ไปที่วัตถุไม่ใช่ตัววัตถุ

  • Instantiation of a class- Instantiation หมายถึงการสร้างตัวแปรประเภทคลาสนั้น ๆ เนื่องจากคลาสเป็นเพียงตัวชี้เมื่อมีการประกาศตัวแปรประเภทคลาสจึงมีการจัดสรรหน่วยความจำสำหรับตัวชี้เท่านั้นไม่ใช่สำหรับวัตถุทั้งหมด เฉพาะเมื่อมีการสร้างอินสแตนซ์โดยใช้หนึ่งในตัวสร้างหน่วยความจำจะถูกจัดสรรให้กับวัตถุ อินสแตนซ์ของคลาสเรียกอีกอย่างว่า 'วัตถุ' แต่อย่าสับสนกับ Object Pascal Objects ในบทช่วยสอนนี้เราจะเขียน 'Object' สำหรับ Pascal Objects และ 'object' สำหรับ conceptual object หรือ class instance

  • Member Variables - ตัวแปรเหล่านี้เป็นตัวแปรที่กำหนดไว้ในคลาสหรืออ็อบเจกต์

  • Member Functions - นี่คือฟังก์ชันหรือโพรซีเดอร์ที่กำหนดไว้ภายในคลาสหรืออ็อบเจ็กต์และใช้เพื่อเข้าถึงข้อมูลอ็อบเจ็กต์

  • Visibility of Members- สมาชิกของ Object หรือ Class เรียกอีกอย่างว่าฟิลด์ ฟิลด์เหล่านี้มีการมองเห็นที่แตกต่างกัน การมองเห็นหมายถึงความสามารถในการเข้าถึงของสมาชิกกล่าวคือสมาชิกเหล่านี้จะสามารถเข้าถึงได้ที่ไหน วัตถุมีระดับการมองเห็นสามระดับ: สาธารณะส่วนตัวและได้รับการป้องกัน ชั้นเรียนมีการมองเห็นห้าประเภท: สาธารณะส่วนตัวส่วนตัวเคร่งครัดได้รับการคุ้มครองและเผยแพร่ เราจะพูดถึงการเปิดเผยในรายละเอียด

  • Inheritance- เมื่อคลาสถูกกำหนดโดยการสืบทอดฟังก์ชันที่มีอยู่ของคลาสพาเรนต์แล้วจะมีการสืบทอด คลาสย่อยจะสืบทอดฟังก์ชันและตัวแปรของคลาสแม่ทั้งหมดหรือบางส่วน วัตถุยังสามารถสืบทอดได้

  • Parent Class- คลาสที่สืบทอดโดยคลาสอื่น เรียกอีกอย่างว่าคลาสพื้นฐานหรือซูเปอร์คลาส

  • Child Class- คลาสที่สืบทอดมาจากคลาสอื่น เรียกอีกอย่างว่าคลาสย่อยหรือคลาสที่ได้รับ

  • Polymorphism- นี่เป็นแนวคิดเชิงวัตถุที่สามารถใช้ฟังก์ชันเดียวกันเพื่อวัตถุประสงค์ที่แตกต่างกันได้ ตัวอย่างเช่นชื่อฟังก์ชันจะยังคงเหมือนเดิม แต่อาจใช้จำนวนอาร์กิวเมนต์ต่างกันและสามารถทำงานต่างกันได้ คลาส Pascal ใช้ความหลากหลาย วัตถุไม่ใช้ความหลากหลาย

  • Overloading- เป็นประเภทของความหลากหลายที่ตัวดำเนินการบางส่วนหรือทั้งหมดมีการใช้งานที่แตกต่างกันขึ้นอยู่กับประเภทของอาร์กิวเมนต์ ฟังก์ชั่นในทำนองเดียวกันสามารถใช้งานได้มากเกินไปด้วยการใช้งานที่แตกต่างกัน คลาส Pascal ใช้การโอเวอร์โหลด แต่อ็อบเจ็กต์ไม่ทำ

  • Data Abstraction - การแสดงข้อมูลใด ๆ ที่มีการซ่อนรายละเอียดการใช้งาน (บทคัดย่อ)

  • Encapsulation - หมายถึงแนวคิดที่เรารวมข้อมูลและฟังก์ชันสมาชิกทั้งหมดเข้าด้วยกันเพื่อสร้างวัตถุ

  • Constructor - หมายถึงฟังก์ชันชนิดพิเศษซึ่งจะถูกเรียกโดยอัตโนมัติเมื่อใดก็ตามที่มีการก่อตัวของวัตถุจากคลาสหรือวัตถุ

  • Destructor - หมายถึงฟังก์ชันชนิดพิเศษซึ่งจะถูกเรียกโดยอัตโนมัติเมื่อใดก็ตามที่ Object หรือ Class ถูกลบหรือออกไปนอกขอบเขต

การกำหนดวัตถุ Pascal

มีการประกาศวัตถุโดยใช้การประกาศประเภท รูปแบบทั่วไปของการประกาศวัตถุมีดังนี้ -

type object-identifier = object  
   private
   field1 : field-type;  
   field2 : field-type;  
   ...
   public
   procedure proc1;  
   function f1(): function-type;
   end;  
var objectvar : object-identifier;

ให้เรากำหนด Rectangle Object ที่มีสมาชิกข้อมูลประเภทจำนวนเต็มสองตัว - 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
* * * *
* * * *
* * * *
* * * *
* * * *

การเปิดเผยของสมาชิกวัตถุ

การมองเห็นบ่งชี้ความสามารถในการเข้าถึงของสมาชิกอ็อบเจ็กต์ สมาชิกวัตถุ Pascal มีการมองเห็นสามประเภท -

ซีเนียร์ No การมองเห็นและการเข้าถึง
1

Public

สมาชิกสามารถใช้โดยหน่วยอื่นนอกหน่วยโปรแกรม

2

Private

สมาชิกสามารถเข้าถึงได้ในหน่วยปัจจุบันเท่านั้น

3

Protected

สมาชิกจะพร้อมใช้งานสำหรับอ็อบเจ็กต์ที่สืบเชื้อสายมาจากอ็อบเจ็กต์พาเรนต์

ตามค่าเริ่มต้นฟิลด์และวิธีการของอ็อบเจ็กต์จะเป็นแบบสาธารณะและจะถูกส่งออกนอกหน่วยปัจจุบัน

ตัวสร้างและตัวทำลายสำหรับวัตถุปาสคาล -

Constructorsเป็นเมธอดชนิดพิเศษซึ่งเรียกโดยอัตโนมัติเมื่อใดก็ตามที่สร้างวัตถุ คุณสร้างตัวสร้างในภาษาปาสคาลเพียงแค่ประกาศวิธีการด้วยตัวสร้างคำหลัก ตามปกติชื่อวิธีการคือ Init อย่างไรก็ตามคุณสามารถระบุตัวระบุที่ถูกต้องของคุณเองได้ คุณสามารถส่งผ่านอาร์กิวเมนต์ได้มากเท่าที่คุณต้องการในฟังก์ชันตัวสร้าง

Destructorsเป็นวิธีการที่เรียกว่าในระหว่างการทำลายวัตถุ เมธอด destructor ทำลายการจัดสรรหน่วยความจำที่สร้างโดยตัวสร้าง

ตัวอย่างต่อไปนี้จะจัดเตรียมคอนสตรัคเตอร์และตัวทำลายสำหรับคลาส Rectangle ซึ่งจะเริ่มต้นความยาวและความกว้างสำหรับสี่เหลี่ยมผืนผ้าในเวลาที่สร้างอ็อบเจ็กต์และทำลายเมื่อมันออกไปนอกขอบเขต

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

การสืบทอดสำหรับวัตถุปาสคาล

อ็อบเจ็กต์ Pascal สามารถเลือกที่จะสืบทอดจากอ็อบเจ็กต์หลัก โปรแกรมต่อไปนี้แสดงให้เห็นถึงการถ่ายทอดทางพันธุกรรมใน Pascal Objects ให้เราสร้างวัตถุอื่นชื่อTableTopซึ่งสืบทอดมาจากออบเจ็กต์ Rectangle

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อ็อบเจ็กต์ได้สืบทอดสมาชิกทั้งหมดของอ็อบเจ็กต์ Rectangle

  • มีวิธีการวาดในTableTopด้วย เมื่อวาดวิธีการที่เรียกว่าใช้โต๊ะวัตถุวาดโต๊ะของได้รับการเรียก

  • มีการตั้งชื่ออินสแตนซ์โดยปริยาย self ที่อ้างถึงอินสแตนซ์ปัจจุบันของวัตถุ

เมื่อโค้ดด้านบนถูกคอมไพล์และเรียกใช้งานจะให้ผลลัพธ์ดังนี้ -

Table Top: 3 by 7
Material: Wood

Calling the Draw Method 
* * * * * * *
* * * * * * *
* * * * * * *
Material: Wood

คุณได้เห็นแล้วว่า Pascal Objects แสดงลักษณะบางประการของกระบวนทัศน์เชิงวัตถุ พวกเขาใช้การห่อหุ้มการซ่อนข้อมูลและการสืบทอด แต่ก็มีข้อ จำกัด เช่นกัน ตัวอย่างเช่น Pascal Objects ไม่ได้มีส่วนร่วมในความหลากหลาย ดังนั้นคลาสจึงถูกใช้กันอย่างแพร่หลายเพื่อใช้พฤติกรรมเชิงวัตถุที่เหมาะสมในโปรแกรมโดยเฉพาะซอฟต์แวร์ที่ใช้ GUI

คลาสถูกกำหนดในลักษณะเดียวกับ Object แต่เป็นตัวชี้ไปที่ Object แทนที่จะเป็น Object เอง ในทางเทคนิคหมายความว่าคลาสถูกจัดสรรบน Heap ของโปรแกรมในขณะที่ Object ถูกจัดสรรบน Stack กล่าวอีกนัยหนึ่งคือเมื่อคุณประกาศตัวแปรประเภทอ็อบเจ็กต์มันจะใช้พื้นที่บนสแต็กเท่ากับขนาดของอ็อบเจ็กต์ แต่เมื่อคุณประกาศตัวแปรประเภทคลาสมันจะใช้ขนาดของตัวชี้เสมอ บนกอง ข้อมูลคลาสจริงจะอยู่ในฮีป

การกำหนดคลาส Pascal

คลาสถูกประกาศในลักษณะเดียวกับอ็อบเจ็กต์โดยใช้การประกาศประเภท รูปแบบทั่วไปของการประกาศคลาสมีดังนี้ -

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ในคลาสรูท คลาสนามธรรมและคลาสคอนกรีตทุกคลาสเป็นลูกหลานของรูทดังนั้นคลาสทั้งหมดจึงมีผู้ทำลายอย่างน้อยหนึ่งคน

ให้เรากำหนดคลาส Rectangle ที่มีสมาชิกข้อมูลประเภทจำนวนเต็มสองตัว - ความยาวและความกว้างและฟังก์ชันสมาชิกบางอย่างเพื่อจัดการกับสมาชิกข้อมูลเหล่านี้และขั้นตอนในการวาดรูปสี่เหลี่ยมผืนผ้า

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;

ให้เราเขียนโปรแกรมที่สมบูรณ์ซึ่งจะสร้างอินสแตนซ์ของคลาสสี่เหลี่ยมผืนผ้าและวาดรูปสี่เหลี่ยมผืนผ้า นี่เป็นตัวอย่างเดียวกับที่เราใช้ในการพูดคุยเกี่ยวกับ Pascal Objects คุณจะพบว่าทั้งสองโปรแกรมเกือบจะเหมือนกันโดยมีข้อยกเว้นดังต่อไปนี้ -

  • คุณจะต้องรวมคำสั่ง {$ mode 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
* * * * * * 
* * * * * * 
* * * * * * 
* * * * * *

การเปิดเผยของสมาชิกชั้นเรียน

การเปิดเผยบ่งชี้ความสามารถในการเข้าถึงของสมาชิกชั้นเรียน สมาชิกชั้นเรียน Pascal มีการมองเห็นห้าประเภท -

ซีเนียร์ No การมองเห็นและการเข้าถึง
1

Public

สมาชิกเหล่านี้สามารถเข้าถึงได้ตลอดเวลา

2

Private

สมาชิกเหล่านี้สามารถเข้าถึงได้เฉพาะในโมดูลหรือหน่วยที่มีข้อกำหนดคลาส สามารถเข้าถึงได้จากภายในวิธีการเรียนหรือจากภายนอก

3

Strict Private

สมาชิกเหล่านี้สามารถเข้าถึงได้จากเมธอดของคลาสเท่านั้น คลาสอื่น ๆ หรือคลาสที่สืบเชื้อสายมาในยูนิตเดียวกันไม่สามารถเข้าถึงได้

4

Protected

สิ่งนี้เหมือนกับไพรเวตยกเว้นสมาชิกเหล่านี้สามารถเข้าถึงประเภทที่สืบต่อกันมาได้แม้ว่าจะถูกนำไปใช้ในโมดูลอื่นก็ตาม

5

Published

สิ่งนี้เหมือนกับ Public แต่คอมไพเลอร์จะสร้างข้อมูลประเภทที่จำเป็นสำหรับการสตรีมอัตโนมัติของคลาสเหล่านี้หากคอมไพเลอร์อยู่ในสถานะ {$ M +} ฟิลด์ที่กำหนดในส่วนที่เผยแพร่ต้องเป็นประเภทคลาส

ตัวสร้างและตัวทำลายสำหรับคลาส Pascal

ตัวสร้างเป็นวิธีการพิเศษซึ่งจะเรียกโดยอัตโนมัติเมื่อใดก็ตามที่สร้างวัตถุ ดังนั้นเราจึงใช้ประโยชน์อย่างเต็มที่จากพฤติกรรมนี้โดยการเริ่มต้นหลาย ๆ สิ่งผ่านฟังก์ชันตัวสร้าง

Pascal มีฟังก์ชันพิเศษที่เรียกว่า create () เพื่อกำหนดคอนสตรัคเตอร์ คุณสามารถส่งผ่านอาร์กิวเมนต์ได้มากเท่าที่คุณต้องการในฟังก์ชันตัวสร้าง

ตัวอย่างต่อไปนี้จะสร้างตัวสร้างหนึ่งตัวสำหรับคลาสชื่อหนังสือและจะเริ่มต้นราคาและชื่อหนังสือในเวลาที่สร้างวัตถุ

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

เช่นเดียวกับตัวสร้างโดยนัยที่มีชื่อว่า create นอกจากนี้ยังมีวิธีการทำลายโดยนัยที่ใช้ทำลายซึ่งคุณสามารถปล่อยทรัพยากรทั้งหมดที่ใช้ในคลาสได้

มรดก

นิยามคลาส Pascal สามารถเลือกที่จะสืบทอดจากนิยามคลาสพาเรนต์ ไวยากรณ์มีดังนี้ -

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 ตัวดำเนินการใช้สำหรับการทำงานมากเกินไป

  • ขั้นตอนการแสดงหนังสือได้รับการประกาศ virtualเพื่อให้วิธีการเดียวกันจากคลาสนวนิยายสามารถทำได้ override มัน.

  • Novels.Create constructor เรียกตัวสร้างคลาสพื้นฐานโดยใช้ 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

คุณต้องใช้คำสั่ง {$ static on} เพื่อใช้สมาชิกแบบคงที่