OOAD-객체 지향 원칙

객체 지향 시스템의 원리

객체 지향 시스템의 개념적 프레임 워크는 객체 모델을 기반으로합니다. 객체 지향 시스템에는 두 가지 범주의 요소가 있습니다.

Major Elements− 전공이란 모델에 이러한 요소 중 하나가 없으면 객체 지향이 중단된다는 의미입니다. 네 가지 주요 요소는-

  • Abstraction
  • Encapsulation
  • Modularity
  • Hierarchy

Minor Elements− 사소한 것은 이러한 요소가 유용하지만 객체 모델의 필수 부분은 아니라는 것을 의미합니다. 세 가지 사소한 요소는-

  • Typing
  • Concurrency
  • Persistence

추출

추상화는 OOP에서 요소 또는 객체의 필수 기능에 초점을 맞추고 외부 또는 우발적 속성을 무시하는 것을 의미합니다. 필수 기능은 객체가 사용되는 컨텍스트와 관련이 있습니다.

Grady Booch는 추상화를 다음과 같이 정의했습니다.

"추상화는 다른 모든 종류의 객체와 구별되는 객체의 필수 특성을 나타내며 따라서 보는 사람의 관점과 관련하여 명확하게 정의 된 개념적 경계를 제공합니다."

Example − Student 클래스를 설계 할 때 enrolment_number, 이름, 코스, 주소 속성은 포함하고 pulse_rate, size_of_shoe와 같은 특성은 교육 기관의 관점에서 무관하기 때문에 제거됩니다.

캡슐화

캡슐화는 클래스 내에서 속성과 메서드를 함께 바인딩하는 프로세스입니다. 캡슐화를 통해 클래스의 내부 세부 정보를 외부에서 숨길 수 있습니다. 클래스에는 클래스에서 제공하는 서비스를 사용할 수있는 사용자 인터페이스를 제공하는 메서드가 있습니다.

모듈성

모듈성은 문제의 전체적인 복잡성을 줄이기 위해 문제 (프로그램)를 모듈 집합으로 분해하는 프로세스입니다. Booch는 모듈성을 다음과 같이 정의했습니다.

"모듈화는 응집력 있고 느슨하게 결합 된 모듈 세트로 분해 된 시스템의 속성입니다."

모듈화는 본질적으로 캡슐화와 연결되어 있습니다. 모듈화는 캡슐화 된 추상화를 모듈 내에서 높은 응집력을 가진 실제 물리적 모듈로 매핑하는 방법으로 시각화 될 수 있으며 모듈 간 상호 작용 또는 결합이 낮습니다.

계층

Grady Booch의 말에 따르면, "계층은 추상화의 순위 또는 순서입니다." 계층 구조를 통해 시스템은 상호 관련된 하위 시스템으로 구성 될 수 있으며, 가장 작은 수준의 구성 요소에 도달 할 때까지 자체 하위 시스템 등을 가질 수 있습니다. “분할 정복”의 원칙을 사용합니다. 계층 구조는 코드 재사용을 허용합니다.

OOA의 두 가지 유형의 계층 구조는 다음과 같습니다.

  • “IS–A” hierarchy− 상속의 계층 적 관계를 정의합니다. 이에 따라 상위 클래스에서 여러 하위 클래스가 파생되어 다시 하위 클래스 등을 가질 수 있습니다. 예를 들어, Flower 클래스에서 Rose 클래스를 파생하는 경우 장미는 "is–a"꽃이라고 말할 수 있습니다.

  • “PART–OF” hierarchy− 한 클래스가 다른 클래스로 구성 될 수있는 집계의 계층 적 관계를 정의합니다. 예를 들어 꽃은 꽃받침, 꽃잎, 수술 및 심피로 구성됩니다. 꽃잎은 "꽃의 일부"라고 말할 수 있습니다.

타자

추상 데이터 유형 이론에 따르면 유형은 요소 집합의 특성화입니다. OOP에서 클래스는 다른 유형과 구별되는 속성을 가진 유형으로 시각화됩니다. 타이핑은 객체가 단일 클래스 또는 유형의 인스턴스라는 개념을 적용하는 것입니다. 또한 다른 유형의 객체가 일반적으로 상호 교환되지 않도록 강제합니다. 절대적으로 필요한 경우 매우 제한된 방식으로 만 교환 할 수 있습니다.

두 가지 유형의 타이핑은-

  • Strong Typing − 여기에서는 프로그래밍 언어 Eiffel에서와 같이 컴파일시 객체에 대한 작업이 확인됩니다.

  • Weak Typing− 여기에서 메시지는 모든 클래스에 보낼 수 있습니다. 작동은 프로그래밍 언어 Smalltalk에서와 같이 실행시에만 확인됩니다.

동시성

운영 체제의 동시성을 통해 여러 작업 또는 프로세스를 동시에 수행 할 수 있습니다. 시스템에 단일 프로세스가 존재하면 단일 제어 스레드가 있다고합니다. 그러나 대부분의 시스템에는 여러 스레드가 있으며 일부는 활성 상태이고 일부는 CPU 대기 중이며 일부는 일시 중단되고 일부는 종료됩니다. 다중 CPU가있는 시스템은 본질적으로 동시 제어 스레드를 허용합니다. 그러나 단일 CPU에서 실행되는 시스템은 적절한 알고리즘을 사용하여 스레드에 동등한 CPU 시간을 제공하여 동시성을 활성화합니다.

객체 지향 환경에는 활성 및 비활성 객체가 있습니다. 활성 개체에는 다른 개체의 스레드와 동시에 실행할 수있는 독립적 인 제어 스레드가 있습니다. 활성 개체는 순전히 순차적 인 개체뿐만 아니라 서로 동기화됩니다.

고집

객체는 메모리 공간을 차지하고 특정 기간 동안 존재합니다. 전통적인 프로그래밍에서 개체의 수명은 일반적으로 개체를 만든 프로그램의 실행 수명이었습니다. 파일 또는 데이터베이스에서 개체 수명은 개체를 만드는 프로세스 기간보다 깁니다. 생성자가 사라진 후에도 객체가 계속 존재하는이 속성을 지속성이라고합니다.