OOAD-객체 지향 설계
분석 단계 후 개념 모델은 객체 지향 설계 (OOD)를 사용하여 객체 지향 모델로 더욱 발전합니다. OOD에서는 분석 모델의 기술 독립적 개념이 구현 클래스에 매핑되고 제약 조건이 식별되고 인터페이스가 설계되어 솔루션 도메인에 대한 모델이 생성됩니다. 요컨대, 구체적인 기술을 기반으로 시스템을 구축하는 방법을 지정하는 자세한 설명이 구성됩니다.
객체 지향 설계의 단계는 다음과 같이 식별 할 수 있습니다.
- 시스템 컨텍스트의 정의
- 시스템 아키텍처 설계
- 시스템의 개체 식별
- 디자인 모델 구축
- 개체 인터페이스 사양
시스템 디자인
객체 지향 시스템 설계에는 시스템의 컨텍스트를 정의한 다음 시스템의 아키텍처를 설계하는 것이 포함됩니다.
Context− 시스템 컨텍스트에는 정적 및 동적 부분이 있습니다. 시스템의 정적 컨텍스트는 하위 시스템의 계층 구조로 확장 된 전체 시스템의 간단한 블록 다이어그램을 사용하여 설계되었습니다. 서브 시스템 모델은 UML 패키지로 표시됩니다. 동적 컨텍스트는 시스템이 환경과 상호 작용하는 방식을 설명합니다. 그것은 사용하여 모델링됩니다use case diagrams.
System Architecture− 시스템 아키텍처는 아키텍처 디자인의 원칙과 도메인 지식에 따라 시스템의 컨텍스트를 기반으로 설계되었습니다. 일반적으로 시스템은 계층으로 분할되고 각 계층은 분해되어 하위 시스템을 형성합니다.
객체 지향 분해
분해는 분할 및 정복의 원칙에 따라 복잡한 대형 시스템을 덜 복잡한 작은 구성 요소의 계층으로 분할하는 것을 의미합니다. 시스템의 각 주요 구성 요소를 하위 시스템이라고합니다. 객체 지향 분해는 시스템의 개별 자율 객체와 이러한 객체 간의 통신을 식별합니다.
분해의 장점은 다음과 같습니다.
개별 구성 요소는 덜 복잡하고 이해하기 쉽고 관리하기 쉽습니다.
전문 기술을 보유한 인력을 분담 할 수 있습니다.
다른 하위 시스템에 영향을주지 않고 하위 시스템을 교체하거나 수정할 수 있습니다.
동시성 식별
동시성을 사용하면 둘 이상의 객체가 동시에 이벤트를 수신하고 둘 이상의 활동이 동시에 실행될 수 있습니다. 동시성은 동적 모델에서 식별되고 표현됩니다.
동시성을 활성화하기 위해 각 동시 요소에는 별도의 제어 스레드가 할당됩니다. 동시성이 개체 수준이면 두 개의 동시 개체에 두 개의 다른 제어 스레드가 할당됩니다. 단일 개체의 두 작업이 본질적으로 동시에 발생하는 경우 해당 개체는 서로 다른 스레드로 분할됩니다.
동시성은 데이터 무결성, 교착 상태 및 기아 문제와 관련이 있습니다. 따라서 동시성이 필요할 때마다 명확한 전략을 세워야합니다. 게다가 동시성은 설계 단계 자체에서 식별되어야하며 구현 단계로 남겨질 수 없습니다.
패턴 식별
응용 프로그램을 설계하는 동안 일부 범주의 문제에 대해 일반적으로 허용되는 일부 솔루션이 채택됩니다. 이것이 디자인 패턴입니다. 패턴은 특정 유형의 애플리케이션 개발 문제에서 사용할 수있는 문서화 된 빌딩 블록 세트로 정의 할 수 있습니다.
일반적으로 사용되는 디자인 패턴은 다음과 같습니다.
- 파사드 패턴
- 모델보기 분리 패턴
- 관찰자 패턴
- 모델보기 컨트롤러 패턴
- 구독 패턴 게시
- 프록시 패턴
이벤트 제어
시스템 설계 중에 시스템 개체에서 발생할 수있는 이벤트를 식별하고 적절하게 처리해야합니다.
이벤트는 시간과 공간에서 위치가있는 중요한 발생의 사양입니다.
모델링 할 수있는 이벤트에는 네 가지 유형이 있습니다.
Signal Event − 한 개체에 의해 던져지고 다른 개체에 의해 잡힌 명명 된 개체.
Call Event − 작업 발송을 나타내는 동기 이벤트.
Time Event − 시간의 흐름을 나타내는 이벤트.
Change Event − 상태 변화를 나타내는 이벤트.
경계 조건 처리
시스템 설계 단계에서는 시스템 전체와 각 하위 시스템의 초기화 및 종료를 처리해야합니다. 문서화 된 다른 측면은 다음과 같습니다.
시스템 시작, 즉 시스템이 초기화되지 않은 상태에서 정상 상태로 전환됩니다.
시스템 종료, 즉 실행중인 모든 스레드 닫기, 리소스 정리 및 보낼 메시지.
시스템의 초기 구성 및 필요할 때 시스템 재구성.
시스템의 예상 실패 또는 원치 않는 종료.
경계 조건은 경계 사용 사례를 사용하여 모델링됩니다.
개체 디자인
하위 시스템의 계층이 개발 된 후 시스템의 개체가 식별되고 세부 정보가 설계됩니다. 여기서 설계자는 시스템 설계 중에 선택한 전략을 자세히 설명합니다. 강조점은 응용 프로그램 도메인 개념에서 컴퓨터 개념으로 이동합니다. 분석 중에 식별 된 객체는 실행 시간, 메모리 소비 및 전체 비용을 최소화하기 위해 구현을 위해 에칭됩니다.
개체 디자인에는 다음 단계가 포함됩니다.
- 개체 식별
- 객체 표현, 즉 디자인 모델의 구성
- 작업 분류
- 알고리즘 설계
- 관계 설계
- 외부 상호 작용을위한 제어 구현
- 클래스와 연관을 모듈로 패키징
개체 식별
객체 디자인의 첫 번째 단계는 객체 식별입니다. 객체 지향 분석 단계에서 식별 된 객체는 클래스로 그룹화되고 실제 구현에 적합하도록 세분화됩니다.
이 단계의 기능은-
각 하위 시스템 또는 패키지의 클래스 식별 및 구체화
클래스 간의 링크 및 연관 정의
클래스 간의 계층 적 연관성, 즉 일반화 / 전문화 및 상속 설계
집계 디자인
객체 표현
클래스가 식별되면 객체 모델링 기술을 사용하여 표현해야합니다. 이 단계에는 기본적으로 UML 다이어그램 구성이 포함됩니다.
생산해야하는 두 가지 유형의 설계 모델이 있습니다.
Static Models − 클래스 다이어그램과 객체 다이어그램을 사용하여 시스템의 정적 구조를 설명합니다.
Dynamic Models − 시스템의 동적 구조를 설명하고 상호 작용 다이어그램과 상태 차트 다이어그램을 사용하여 클래스 간의 상호 작용을 보여줍니다.
작업 분류
이 단계에서는 OOA 단계에서 개발 된 세 가지 모델 즉, 객체 모델, 동적 모델, 기능 모델을 결합하여 객체에 대해 수행 할 작업을 정의합니다. 작업은 수행 방법이 아니라 수행 할 작업을 지정합니다.
다음 작업은 작업과 관련하여 수행됩니다-
시스템의 각 객체에 대한 상태 전이 다이어그램이 개발됩니다.
작업은 객체가 수신 한 이벤트에 대해 정의됩니다.
하나의 이벤트가 동일하거나 다른 개체에서 다른 이벤트를 트리거하는 경우가 식별됩니다.
작업 내의 하위 작업이 식별됩니다.
주요 작업은 데이터 흐름 다이어그램으로 확장됩니다.
알고리즘 설계
객체의 작업은 알고리즘을 사용하여 정의됩니다. 알고리즘은 작업에있는 문제를 해결하는 단계적 절차입니다. 알고리즘은 수행 방법에 중점을 둡니다.
주어진 작업에 해당하는 알고리즘이 둘 이상있을 수 있습니다. 대체 알고리즘이 식별되면 주어진 문제 도메인에 대해 최적의 알고리즘이 선택됩니다. 최적의 알고리즘을 선택하기위한 메트릭은 다음과 같습니다.
Computational Complexity − 복잡성은 계산 시간 및 메모리 요구 사항 측면에서 알고리즘의 효율성을 결정합니다.
Flexibility − 유연성은 선택한 알고리즘이 다양한 환경에서 적절성을 잃지 않고 적절하게 구현 될 수 있는지 여부를 결정합니다.
Understandability − 선택한 알고리즘이 이해하고 구현하기 쉬운 지 여부를 결정합니다.
관계 설계
관계를 구현하기위한 전략은 개체 디자인 단계에서 작성해야합니다. 해결되는 주요 관계는 연결, 집계 및 상속으로 구성됩니다.
디자이너는 연관에 대해 다음을 수행해야합니다.
연관이 단방향인지 양방향인지 식별합니다.
연결 경로를 분석하고 필요한 경우 업데이트합니다.
다 대다 관계의 경우 연관을 별개의 개체로 구현합니다. 또는 일대일 또는 일대 다 관계의 경우 다른 개체에 대한 링크로.
상속과 관련하여 디자이너는 다음을 수행해야합니다.
클래스와 그 연관성을 조정하십시오.
추상 클래스를 식별합니다.
필요할 때 행동을 공유 할 수 있도록 준비하십시오.
통제의 구현
개체 설계자는 상태 차트 모델의 전략에 개선 사항을 통합 할 수 있습니다. 시스템 설계에서는 동적 모델을 실현하기위한 기본 전략이 만들어집니다. 개체 설계 중에이 전략은 적절한 구현을 위해 적절하게 장식됩니다.
동적 모델의 구현을위한 접근 방식은 다음과 같습니다.
Represent State as a Location within a Program− 이것은 제어 위치가 프로그램 상태를 정의하는 전통적인 절차 중심 접근 방식입니다. 유한 상태 머신은 프로그램으로 구현 될 수 있습니다. 전환은 입력 문을 형성하고, 기본 제어 경로는 명령어 시퀀스를 형성하고, 분기는 조건을 형성하고, 역방향 경로는 루프 또는 반복을 형성합니다.
State Machine Engine−이 접근 방식은 상태 머신 엔진 클래스를 통해 상태 머신을 직접 나타냅니다. 이 클래스는 애플리케이션에서 제공하는 일련의 전환 및 작업을 통해 상태 머신을 실행합니다.
Control as Concurrent Tasks−이 접근 방식에서 객체는 프로그래밍 언어 또는 운영 체제에서 작업으로 구현됩니다. 여기서 이벤트는 작업 간 호출로 구현됩니다. 실제 개체의 고유 한 동시성을 유지합니다.
패키징 클래스
모든 대규모 프로젝트에서는 구현을 모듈 또는 패키지로 세 심하게 분할하는 것이 중요합니다. 객체 디자인 중에 클래스와 객체는 여러 그룹이 프로젝트에서 협력 적으로 작업 할 수 있도록 패키지로 그룹화됩니다.
포장의 다른 측면은 다음과 같습니다.
Hiding Internal Information from Outside View − 클래스를 "블랙 박스"로 볼 수 있으며 클래스의 클라이언트가 코드를 수정하지 않고도 클래스 구현을 변경할 수 있습니다.
Coherence of Elements − 클래스, 작업 또는 모듈과 같은 요소는 일관된 계획으로 구성되고 모든 부분이 본질적으로 관련되어 공통 목표를 달성 할 수있는 경우 일관성이 있습니다.
Construction of Physical Modules − 다음 지침은 물리적 모듈을 구성하는 데 도움이됩니다 −
모듈의 클래스는 동일한 복합 객체에서 유사한 사물 또는 구성 요소를 나타내야합니다.
밀접하게 연결된 클래스는 동일한 모듈에 있어야합니다.
연결되지 않거나 약하게 연결된 클래스는 별도의 모듈에 배치해야합니다.
모듈은 좋은 응집력을 가져야합니다. 즉, 구성 요소 간의 협력이 높아야합니다.
모듈은 다른 모듈과 낮은 결합을 가져야합니다. 즉, 모듈 간의 상호 작용 또는 상호 의존성이 최소화되어야합니다.
디자인 최적화
분석 모델은 시스템에 대한 논리적 정보를 캡처하는 반면 디자인 모델은 효율적인 정보 액세스를 지원하기 위해 세부 정보를 추가합니다. 디자인을 구현하기 전에 구현을보다 효율적으로 만들 수 있도록 최적화해야합니다. 최적화의 목표는 시간, 공간 및 기타 메트릭 측면에서 비용을 최소화하는 것입니다.
그러나 구현의 용이성, 유지 보수성 및 확장 성 또한 중요한 관심사이므로 설계 최적화는 초과해서는 안됩니다. 완벽하게 최적화 된 디자인이 더 효율적이지만 가독성과 재사용 가능성이 떨어지는 경우가 종종 있습니다. 따라서 디자이너는 둘 사이의 균형을 유지해야합니다.
설계 최적화를 위해 수행 할 수있는 다양한 작업은 다음과 같습니다.
- 중복 연결 추가
- 사용할 수없는 연결 생략
- 알고리즘 최적화
- 복잡한 표현식의 재 계산을 방지하기 위해 파생 된 속성 저장
중복 연결 추가
설계 최적화 중에 새 연관을 유도하여 액세스 비용을 줄일 수 있는지 확인합니다. 이러한 중복 연결은 정보를 추가하지 않을 수 있지만 전체 모델의 효율성을 높일 수 있습니다.
사용할 수없는 연결 생략
너무 많은 연결이 있으면 시스템을 해독 할 수 없게되어 시스템의 전체 효율성이 저하 될 수 있습니다. 따라서 최적화 중에 사용할 수없는 모든 연결이 제거됩니다.
알고리즘 최적화
객체 지향 시스템에서 데이터 구조 및 알고리즘의 최적화는 협업 방식으로 수행됩니다. 클래스 디자인이 제자리에 있으면 작업과 알고리즘을 최적화해야합니다.
알고리즘 최적화는-
- 계산 작업 순서 재정렬
- 기능 모델에 배치 된 루프의 실행 순서 반전
- 알고리즘 내에서 데드 경로 제거
파생 속성 저장 및 저장
파생 속성은 값이 다른 속성 (기본 속성)의 함수로 계산되는 속성입니다. 필요할 때마다 파생 된 속성 값을 다시 계산하는 것은 시간이 많이 걸리는 절차입니다. 이를 방지하기 위해 값을 계산하여 계산 된 형식으로 저장할 수 있습니다.
그러나 이것은 업데이트 이상, 즉 파생 된 속성의 값에 대응하는 변경없이 기본 속성의 값의 변경을 야기 할 수 있습니다. 이를 피하기 위해 다음 단계가 수행됩니다.
기본 속성 값이 업데이트 될 때마다 파생 된 속성도 다시 계산됩니다.
파생 된 모든 속성은 각 업데이트 이후가 아니라 그룹에서 주기적으로 다시 계산되고 업데이트됩니다.
설계 문서
문서화는 소프트웨어 제작 절차를 기록하는 소프트웨어 개발 프로세스의 필수 부분입니다. 설계 결정은 설계를 다른 사람에게 전송하기위한 중요하지 않은 소프트웨어 시스템에 대해 문서화되어야합니다.
사용 영역
보조 제품이지만 특히 다음 영역에서 좋은 문서화는 필수 불가결합니다.
- 여러 개발자가 개발중인 소프트웨어를 설계 할 때
- 반복적 인 소프트웨어 개발 전략에서
- 소프트웨어 프로젝트의 후속 버전 개발
- 소프트웨어 평가 용
- 테스트 조건 및 영역 찾기
- 소프트웨어 유지 관리를 위해.
내용
유익한 문서에는 기본적으로 다음 내용이 포함되어야합니다.
High–level system architecture − 공정 다이어그램 및 모듈 다이어그램
Key abstractions and mechanisms − 클래스 다이어그램 및 개체 다이어그램.
Scenarios that illustrate the behavior of the main aspects − 행동 다이어그램
풍모
좋은 문서의 특징은-
간결하고 동시에 모호하지 않고 일관성 있고 완전합니다.
시스템의 요구 사항 사양에 따라 추적 가능
Well-structured
설명이 아닌 다이어그램