Pascal - ขั้นตอน

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.