파스칼-절차

Procedures 단일 값을 반환하는 대신 결과 그룹을 얻을 수있는 하위 프로그램입니다.

절차 정의

Pascal에서 절차는 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);

프로 시저 호출

프로 시저를 생성하는 동안 프로 시저가 수행해야하는 작업에 대한 정의를 제공합니다. 프로 시저를 사용하려면 정의 된 작업을 수행하기 위해 해당 프로 시저를 호출해야합니다. 프로그램이 프로 시저를 호출하면 프로그램 제어가 호출 된 프로 시저로 전송됩니다. 호출 된 프로시 저는 정의 된 작업을 수행하고 마지막 end 문에 도달하면 제어를 호출 프로그램으로 반환합니다.

프로 시저를 호출하려면 아래와 같이 프로 시저 이름과 함께 필요한 매개 변수를 전달하면됩니다.

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 a를 사용하여 주어진 숫자에 대해 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 서브 프로그램의.

형식 매개 변수는 서브 프로그램 내부의 다른 지역 변수처럼 작동하며 서브 프로그램에 들어갈 때 생성되고 종료시 삭제됩니다.

서브 프로그램을 호출하는 동안 인수를 서브 프로그램에 전달할 수있는 두 가지 방법이 있습니다.

Sr. 아니요 통화 유형 및 설명
1 가치로 부르기

이 메소드는 인수의 실제 값을 서브 프로그램의 형식 매개 변수로 복사합니다. 이 경우 서브 프로그램 내의 매개 변수에 대한 변경 사항은 인수에 영향을주지 않습니다.

2 참조로 전화

이 메서드는 인수의 주소를 형식 매개 변수에 복사합니다. 하위 프로그램 내에서 주소는 호출에 사용 된 실제 인수에 액세스하는 데 사용됩니다. 이것은 매개 변수에 대한 변경 사항이 인수에 영향을 미친다는 것을 의미합니다.

기본적으로 Pascal은 call by value인수를 전달합니다. 일반적으로 이는 하위 프로그램 내의 코드가 하위 프로그램을 호출하는 데 사용되는 인수를 변경할 수 없음을 의미합니다. 'Pascal-Functions'장에서 사용한 예제 프로그램은 다음을 사용하여 max ()라는 함수를 호출했습니다.call by value.

반면 여기에 제공된 예제 프로그램 ( exProcedure )은 다음을 사용하여 findMin () 프로 시저를 호출합니다.call by reference.