파스칼-객체 지향

우리는 태양, 지구, 달 등과 같은 다른 물체로 만들어진 우주를 상상할 수 있습니다. 마찬가지로, 우리는 바퀴, 스티어링, 기어 등과 같은 다른 물체로 만들어진 자동차를 상상할 수 있습니다. 같은 방식으로, 객체 지향 프로그래밍 개념이 있습니다. 모든 것을 객체로 가정하고 다른 객체를 사용하여 소프트웨어를 구현합니다. Pascal에는 실제 객체를 구현하는 데 사용되는 두 가지 구조 데이터 유형이 있습니다.

  • 개체 유형
  • 클래스 유형

객체 지향 개념

자세히 알아보기 전에 객체 지향 파스칼과 관련된 중요한 파스칼 용어를 정의하겠습니다.

  • Object− 객체는 레코드와 같은 필드를 포함하는 특별한 종류의 레코드입니다. 그러나 레코드와 달리 개체는 개체의 일부로 프로 시저 및 기능을 포함합니다. 이러한 프로 시저 및 함수는 개체 유형과 관련된 메서드에 대한 포인터로 유지됩니다.

  • Class− Class는 Object와 거의 같은 방식으로 정의되지만 생성 방식에 차이가 있습니다. 클래스는 프로그램의 힙에 할당되는 반면 객체는 스택에 할당됩니다. 개체 자체가 아니라 개체에 대한 포인터입니다.

  • Instantiation of a class− 인스턴스화는 해당 클래스 유형의 변수를 생성하는 것을 의미합니다. 클래스는 포인터 일 뿐이므로 클래스 타입의 변수를 선언하면 전체 객체가 아닌 포인터에 대해서만 메모리가 할당됩니다. 생성자 중 하나를 사용하여 인스턴스화 될 때만 메모리가 개체에 할당됩니다. 클래스의 인스턴스는 '오브젝트'라고도하지만 오브젝트 파스칼 오브젝트와 혼동하지 마십시오. 이 튜토리얼에서 우리는 Pascal 객체에 대해 'Object'를 작성하고 개념적 객체 또는 클래스 인스턴스에 대해 'object'를 작성합니다.

  • Member Variables − 이들은 클래스 또는 객체 내부에 정의 된 변수입니다.

  • Member Functions − 이들은 클래스 또는 객체 내부에 정의 된 함수 또는 절차이며 객체 데이터에 액세스하는 데 사용됩니다.

  • Visibility of Members− 객체 또는 클래스의 구성원을 필드라고도합니다. 이 필드는 가시성이 다릅니다. 가시성은 구성원의 접근성, 즉 이러한 구성원이 액세스 할 수있는 정확한 위치를 나타냅니다. 개체에는 공개, 비공개 및 보호의 세 가지 가시성 수준이 있습니다. 클래스에는 공개, 비공개, 엄격 비공개, 보호 및 게시의 다섯 가지 가시성 유형이 있습니다. 가시성을 자세히 논의하겠습니다.

  • Inheritance− 클래스가 부모 클래스의 기존 기능을 상속하여 정의 된 경우 상속되었다고합니다. 여기서 자식 클래스는 부모 클래스의 멤버 함수와 변수를 모두 또는 일부 상속합니다. 객체는 상속 될 수도 있습니다.

  • Parent Class− 다른 클래스에 의해 상속 된 클래스. 이를 기본 클래스 또는 수퍼 클래스라고도합니다.

  • Child Class− 다른 클래스에서 상속되는 클래스. 이를 하위 클래스 또는 파생 클래스라고도합니다.

  • Polymorphism− 동일한 기능을 다른 용도로 사용할 수있는 객체 지향 개념입니다. 예를 들어 함수 이름은 동일하게 유지되지만 인수 개수가 다를 수 있고 다른 작업을 수행 할 수 있습니다. 파스칼 클래스는 다형성을 구현합니다. 객체는 다형성을 구현하지 않습니다.

  • Overloading− 연산자의 일부 또는 전체가 인수 유형에 따라 다른 구현을 갖는 다형성 유형입니다. 마찬가지로 함수는 다른 구현으로 오버로드 될 수 있습니다. 파스칼 클래스는 오버로딩을 구현하지만 오브젝트는 그렇지 않습니다.

  • Data Abstraction − 구현 세부 정보가 숨겨져있는 (추상화 된) 데이터 표현.

  • Encapsulation − 모든 데이터와 멤버 함수를 함께 캡슐화하여 객체를 형성하는 개념을 의미합니다.

  • Constructor − 클래스 또는 Object로부터 객체 형성이있을 때마다 자동으로 호출되는 특별한 유형의 함수를 의미합니다.

  • Destructor − Object 또는 Class가 삭제되거나 범위를 벗어날 때마다 자동으로 호출되는 특수한 유형의 함수를 의미합니다.

파스칼 객체 정의

객체는 유형 선언을 사용하여 선언됩니다. 객체 선언의 일반적인 형식은 다음과 같습니다.

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

두 개의 정수형 데이터 멤버가있는 Rectangle 객체를 정의하겠습니다. lengthwidth 이러한 데이터 멤버를 조작하는 일부 멤버 함수와 사각형을 그리는 프로 시저가 있습니다.

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
* * * *
* * * *
* * * *
* * * *
* * * *

개체 구성원의 가시성

가시성은 오브젝트 멤버의 액세스 가능성을 나타냅니다. 파스칼 객체 멤버는 세 가지 유형의 가시성을 가지고 있습니다.

Sr. 아니요 가시성 및 접근성
1

Public

멤버는 프로그램 단위 외부의 다른 단위에서 사용할 수 있습니다.

2

Private

구성원은 현재 단위에서만 액세스 할 수 있습니다.

Protected

멤버는 상위 개체의 하위 개체에만 사용할 수 있습니다.

기본적으로 개체의 필드와 메서드는 공용이며 현재 단위 외부로 내보내집니다.

파스칼 객체를위한 생성자와 소멸자 −

Constructors객체가 생성 될 때마다 자동으로 호출되는 특수한 유형의 메서드입니다. 키워드 생성자로 메서드를 선언하는 것만으로 Pascal에서 생성자를 만듭니다. 일반적으로 메서드 이름은 Init이지만 유효한 식별자를 직접 제공 할 수 있습니다. 생성자 함수에 원하는만큼 인수를 전달할 수 있습니다.

Destructors객체를 파괴하는 동안 호출되는 메서드입니다. 소멸자 메서드는 생성자가 만든 모든 메모리 할당을 파괴합니다.

다음 예제는 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

파스칼 객체의 상속

파스칼 객체는 선택적으로 부모 객체에서 상속 할 수 있습니다. 다음 프로그램은 파스칼 객체의 상속을 보여줍니다. 이름이 다른 개체를 만들어 보겠습니다.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