소프트웨어 설계 전략
소프트웨어 디자인은 소프트웨어 요구 사항을 소프트웨어 구현으로 개념화하는 프로세스입니다. 소프트웨어 설계는 사용자 요구 사항을 도전으로 받아들이고 최적의 솔루션을 찾으려고합니다. 소프트웨어가 개념화되는 동안 의도 된 솔루션을 구현하기위한 최상의 설계를 찾기위한 계획이 작성됩니다.
소프트웨어 디자인에는 여러 가지 변형이 있습니다. 간략하게 살펴 보겠습니다.
구조화 된 디자인
구조화 된 디자인은 문제를 여러 가지 잘 구성된 솔루션 요소로 개념화 한 것입니다. 기본적으로 솔루션 설계와 관련이 있습니다. 구조화 된 설계의 이점은 문제가 해결되는 방식을 더 잘 이해할 수 있다는 것입니다. 구조화 된 디자인은 또한 디자이너가 문제에 더 정확하게 집중하는 것을 더 간단하게 만듭니다.
구조화 된 디자인은 대부분 문제를 여러 개의 작은 문제로 나누고 전체 문제가 해결 될 때까지 각각의 작은 문제를 개별적으로 해결하는 '분할 정복'전략을 기반으로합니다.
작은 문제는 솔루션 모듈을 통해 해결됩니다. 구조화 된 설계는 이러한 모듈이 정확한 솔루션을 얻기 위해 잘 구성되어 있음을 강조합니다.
이러한 모듈은 계층 구조로 배열됩니다. 그들은 서로 의사 소통합니다. 좋은 구조적 설계는 항상 여러 모듈 간의 통신에 대한 몇 가지 규칙을 따릅니다.
Cohesion -기능적으로 관련된 모든 요소의 그룹화.
Coupling -다른 모듈 간의 통신.
좋은 구조적 설계는 높은 응집력과 낮은 결합 배열을 갖습니다.
기능 지향 디자인
기능 지향 설계에서 시스템은 기능으로 알려진 많은 작은 하위 시스템으로 구성됩니다. 이러한 기능은 시스템에서 중요한 작업을 수행 할 수 있습니다. 이 시스템은 모든 기능의 평면도로 간주됩니다.
기능 지향 디자인은 분할 및 정복 방법론이 사용되는 구조적 디자인의 일부 속성을 상속합니다.
이 설계 메커니즘은 전체 시스템을 더 작은 기능으로 분할하여 정보와 그 작동을 은폐하여 추상화 수단을 제공합니다. 이러한 기능 모듈은 정보를 전달하고 전 세계적으로 사용 가능한 정보를 사용하여 정보를 서로 공유 할 수 있습니다.
함수의 또 다른 특징은 프로그램이 함수를 호출 할 때 해당 함수가 프로그램의 상태를 변경한다는 것입니다. 이는 때때로 다른 모듈에서 허용되지 않습니다. 기능 지향 설계는 시스템 상태가 중요하지 않고 프로그램 / 기능이 상태가 아닌 입력에서 작동하는 경우 잘 작동합니다.
디자인 과정
- 전체 시스템은 데이터 흐름 다이어그램을 통해 시스템에서 데이터가 어떻게 흐르는 지 보여줍니다.
- DFD는 기능이 전체 시스템의 데이터 및 상태를 변경하는 방법을 보여줍니다.
- 전체 시스템은 논리적으로 시스템에서의 작동에 따라 기능이라고하는 작은 단위로 분류됩니다.
- 그런 다음 각 기능에 대해 자세히 설명합니다.
객체 지향 디자인
객체 지향 디자인은 소프트웨어 시스템과 관련된 기능 대신 엔티티와 그 특성을 중심으로 작동합니다. 이 디자인 전략은 개체와 그 특성에 중점을 둡니다. 소프트웨어 솔루션의 전체 개념은 참여하는 엔티티를 중심으로합니다.
객체 지향 디자인의 중요한 개념을 살펴 보겠습니다.
- Objects - 솔루션 디자인에 관련된 모든 엔터티를 개체라고합니다. 예를 들어, 사람, 은행, 회사 및 고객은 객체로 취급됩니다. 모든 엔티티에는 연관된 속성이 있으며 속성에 대해 수행 할 메소드가 있습니다.
Classes - 클래스는 객체에 대한 일반화 된 설명입니다. 객체는 클래스의 인스턴스입니다. 클래스는 객체가 가질 수있는 모든 속성과 객체의 기능을 정의하는 메서드를 정의합니다.
솔루션 설계에서 속성은 변수로 저장되고 기능은 방법 또는 절차를 통해 정의됩니다.
- Encapsulation - OOD에서는 속성 (데이터 변수)과 메서드 (데이터에 대한 작업)가 함께 묶여있는 것을 캡슐화라고합니다. 캡슐화는 객체의 중요한 정보를 함께 묶을뿐만 아니라 외부 세계의 데이터 및 메서드 액세스를 제한합니다. 이것을 정보 숨김이라고합니다.
- Inheritance - OOD를 사용하면 하위 또는 하위 클래스가 직계 수퍼 클래스에서 허용 된 변수 및 메소드를 가져오고 구현하고 재사용 할 수있는 계층 적 방식으로 유사한 클래스를 쌓을 수 있습니다. 이 OOD 속성을 상속이라고합니다. 이렇게하면 특정 클래스를 정의하고 특정 클래스에서 일반화 된 클래스를 쉽게 만들 수 있습니다.
- Polymorphism - OOD 언어는 유사한 작업을 수행하지만 인수가 다른 메서드에 동일한 이름을 할당 할 수있는 메커니즘을 제공합니다. 이를 다형성 (polymorphism)이라고하며 단일 인터페이스가 다양한 유형에 대한 작업을 수행 할 수 있도록합니다. 함수가 호출되는 방법에 따라 코드의 각 부분이 실행됩니다.
디자인 과정
소프트웨어 설계 프로세스는 일련의 잘 정의 된 단계로 인식 될 수 있습니다. 디자인 접근 방식 (기능 지향 또는 객체 지향)에 따라 다르지만 다음 단계가 포함될 수 있습니다.
- 솔루션 설계는 요구 사항 또는 이전에 사용 된 시스템 및 / 또는 시스템 시퀀스 다이어그램에서 생성됩니다.
- 객체는 속성 특성의 유사성을 대신하여 식별되고 클래스로 그룹화됩니다.
- 클래스 계층 구조 및 이들 간의 관계가 정의됩니다.
- 애플리케이션 프레임 워크가 정의됩니다.
소프트웨어 설계 접근 방식
다음은 소프트웨어 설계를위한 두 가지 일반적인 접근 방식입니다.
하향식 설계
우리는 시스템이 하나 이상의 하위 시스템으로 구성되고 여러 구성 요소를 포함하고 있음을 알고 있습니다. 또한 이러한 하위 시스템 및 구성 요소는 하위 시스템 및 구성 요소의 집합을 가질 수 있으며 시스템에서 계층 구조를 만듭니다.
하향식 설계는 전체 소프트웨어 시스템을 하나의 엔티티로 취한 다음이를 분해하여 일부 특성에 따라 둘 이상의 하위 시스템 또는 구성 요소를 달성합니다. 그런 다음 각 하위 시스템 또는 구성 요소는 시스템으로 처리되고 추가로 분해됩니다. 이 프로세스는 하향식 계층 구조에서 가장 낮은 수준의 시스템에 도달 할 때까지 계속 실행됩니다.
하향식 설계는 일반화 된 시스템 모델에서 시작하여 더 구체적인 부분을 계속 정의합니다. 모든 구성 요소가 구성되면 전체 시스템이 존재합니다.
하향식 설계는 소프트웨어 솔루션을 처음부터 설계해야하고 특정 세부 사항을 알 수없는 경우에 더 적합합니다.
상향식 설계
상향식 설계 모델은 가장 구체적이고 기본적인 구성 요소로 시작됩니다. 기본 또는 하위 수준의 구성 요소를 사용하여 더 높은 수준의 구성 요소 구성을 진행합니다. 원하는 시스템이 하나의 단일 구성 요소로 발전하지 않을 때까지 더 높은 수준의 구성 요소를 계속 생성합니다. 각 수준이 높을수록 추상화의 양이 증가합니다.
상향식 전략은 새로운 시스템에서 기본 프리미티브를 사용할 수있는 기존 시스템에서 시스템을 만들어야 할 때 더 적합합니다.
하향식 및 상향식 접근 방식은 모두 개별적으로 실용적이지 않습니다. 대신 두 가지의 좋은 조합이 사용됩니다.