OOAD-기능 모델링
Functional Modeling은 객체 지향 분석 모델의 프로세스 관점과 시스템이 수행해야하는 작업에 대한 개요를 제공합니다. 데이터 흐름 다이어그램 (DFD)을 사용하여 시스템의 내부 프로세스 기능을 정의합니다. 데이터 값이 계산 될 때 파생되는 방법 또는 계산이 필요한 이유를 나타내지 않고 데이터 값의 기능적 파생을 설명합니다.
데이터 흐름 다이어그램
기능적 모델링은 DFD의 계층 구조를 통해 표현됩니다. DFD는 시스템에 대한 입력, 입력 처리, 시스템 출력 및 내부 데이터 저장소를 보여주는 시스템의 그래픽 표현입니다. DFD는 개체 또는 시스템에서 수행되는 일련의 변환 또는 계산과 변환에 영향을주는 외부 제어 및 개체를 보여줍니다.
Rumbaugh et al. DFD는 "데이터 흐름 다이어그램은 다른 개체의 대상으로 변환하는 프로세스를 통해 개체의 소스에서 데이터 값의 흐름을 보여주는 그래프"라고 정의했습니다.
DFD의 네 가지 주요 부분은 다음과 같습니다.
- Processes,
- 데이터 흐름,
- 배우 및
- 데이터 저장소.
DFD의 다른 부분은-
- 제약 및
- 제어 흐름.
DFD의 특징
프로세스
프로세스는 데이터 값을 변환하는 계산 활동입니다. 전체 시스템을 높은 수준의 프로세스로 시각화 할 수 있습니다. 프로세스는 더 작은 구성 요소로 더 나눌 수 있습니다. 최하위 프로세스는 간단한 기능 일 수 있습니다.
Representation in DFD − 프로세스는 내부에 이름이 쓰여진 타원으로 표시되며 고정 된 수의 입력 및 출력 데이터 값을 포함합니다.
Example − 다음 그림은 두 정수를 입력으로 받아들이고 HCF (최고 공약수)와 LCM (최소 공배수)을 출력하는 Compute_HCF_LCM 프로세스를 보여줍니다.
데이터 흐름
데이터 흐름은 두 프로세스 간의 데이터 흐름을 나타냅니다. 행위자와 프로세스 사이 또는 데이터 저장소와 프로세스 사이에있을 수 있습니다. 데이터 흐름은 계산의 특정 지점에서 데이터 항목의 값을 나타냅니다. 이 값은 데이터 흐름에 의해 변경되지 않습니다.
Representation in DFD − 데이터 흐름은 전달되는 데이터 항목의 이름이 표시된 방향성 호 또는 화살표로 표시됩니다.
위 그림에서 Integer_a 및 Integer_b는 프로세스에 대한 입력 데이터 흐름을 나타내고 LCM 및 HCF는 출력 데이터 흐름입니다.
다음과 같은 경우 데이터 흐름이 분기 될 수 있습니다.
출력 값은 다음 그림과 같이 여러 위치로 전송됩니다. 여기서 출력 화살표는 동일한 값을 나타내므로 레이블이 지정되지 않습니다.
데이터 흐름에는 집계 값이 포함되며 다음 그림과 같이 각 구성 요소가 서로 다른 위치로 전송됩니다. 여기에서 분기 된 각 구성 요소에 레이블이 표시됩니다.
배우
액터는 데이터를 생성하고 시스템에 입력하거나 시스템에서 생성 한 데이터를 소비하여 시스템과 상호 작용하는 활성 개체입니다. 즉, 행위자는 데이터 소스 및 싱크 역할을합니다.
Representation in DFD− 액터는 직사각형으로 표시됩니다. 액터는 입력 및 출력에 연결되고 DFD의 경계에 있습니다.
Example − 다음 그림은 카운터 판매 시스템에서 행위자, 즉 Customer와 Sales_Clerk를 보여줍니다.
데이터 저장소
데이터 저장소는 데이터 저장소 역할을하는 수동 개체입니다. 액터와는 달리 어떤 작업도 수행 할 수 없습니다. 데이터를 저장하고 저장된 데이터를 검색하는 데 사용됩니다. 데이터 구조, 디스크 파일 또는 데이터베이스의 테이블을 나타냅니다.
Representation in DFD− 데이터 저장소는 데이터 저장소의 이름을 포함하는 두 개의 평행선으로 표시됩니다. 각 데이터 저장소는 하나 이상의 프로세스에 연결됩니다. 입력 화살표에는 데이터 저장소의 내용을 수정하기위한 정보가 포함되고 출력 화살표에는 데이터 저장소에서 검색된 정보가 포함됩니다. 정보의 일부를 검색 할 때 출력 화살표에 레이블이 지정됩니다. 레이블이없는 화살표는 전체 데이터 검색을 나타냅니다. 양방향 화살표는 검색과 업데이트를 모두 의미합니다.
Example− 다음 그림은 모든 판매의 세부 정보를 저장하는 데이터 저장소 Sales_Record를 보여줍니다. 데이터 저장소에 대한 입력은 품목, 청구 금액, 날짜 등과 같은 판매 세부 정보로 구성됩니다. 평균 판매를 찾기 위해 프로세스는 판매 레코드를 검색하고 평균을 계산합니다.
제약
제약 조건은 시간이 지남에 따라 충족되어야하는 조건 또는 제한 사항을 지정합니다. 새 규칙을 추가하거나 기존 규칙을 수정할 수 있습니다. 제약 조건은 객체 지향 분석의 세 가지 모델 모두에 나타날 수 있습니다.
개체 모델링에서 제약 조건은 개체 간의 관계를 정의합니다. 또한 개체가 다른 시간에 취할 수있는 다른 값 간의 관계를 정의 할 수도 있습니다.
동적 모델링에서 제약 조건은 서로 다른 개체의 상태와 이벤트 간의 관계를 정의합니다.
Functional Modelling에서 제약 조건은 변환 및 계산에 대한 제한을 정의합니다.
Representation − 제약 조건은 중괄호 안의 문자열로 렌더링됩니다.
Example− 다음 그림은 영업 부서의 모든 직원에게 인센티브를 제공하고 HR 부서의 모든 직원의 급여를 인상하기로 결정한 회사 직원의 급여를 계산하기위한 DFD의 일부를 보여줍니다. 제약 조건 {Dept : Sales}는 부서가 판매 인 경우에만 인센티브가 계산되도록하고 제약 {Dept : HR}은 부서가 HR 인 경우에만 증가분을 계산하도록합니다.
제어 흐름
프로세스는 특정 부울 값과 연관 될 수 있으며 프로세스에 대한 직접적인 입력은 아니지만 값이 true 인 경우에만 평가됩니다. 이러한 부울 값을 제어 흐름이라고합니다.
Representation in DFD − 제어 흐름은 부울 값을 생성하는 프로세스에서 제어되는 프로세스까지 점선으로 표시됩니다.
Example− 다음 그림은 산술 분할을위한 DFD를 나타냅니다. 제수는 0이 아닌지 테스트됩니다. 0이 아니면 제어 흐름 OK의 값이 True이고 이후에 Divide 프로세스가 몫과 나머지를 계산합니다.
시스템의 DFD 모델 개발
시스템의 DFD 모델을 개발하기 위해 DFD의 계층 구조가 구성됩니다. 최상위 레벨 DFD는 단일 프로세스와 그와 상호 작용하는 액터로 구성됩니다.
연속되는 각 하위 수준에서 추가 세부 정보가 점차적으로 포함됩니다. 프로세스를 하위 프로세스로 분해하고 하위 프로세스 간의 데이터 흐름을 식별하고 제어 흐름을 결정하고 데이터 저장소를 정의합니다. 프로세스를 분해하는 동안 프로세스 내부 또는 외부의 데이터 흐름은 다음 수준의 DFD에서 데이터 흐름과 일치해야합니다.
Example− 도매점의 거래를 자동화하는 소프트웨어 시스템 인 Wholesaler Software를 고려해 보겠습니다. 상점은 대량으로 판매되며 상인과 소매점 소유자로 구성된 고객이 있습니다. 각 고객은 자신의 세부 사항을 등록해야하며 고유 한 고객 코드 인 C_Code가 제공됩니다. 판매가 완료되면 상점에서 세부 정보를 등록하고 배송을 위해 상품을 보냅니다. 매장은 매년 총 매출액과 주인의 결정에 따라 은화 또는 금화로 구성된 크리스마스 선물을 고객에게 배포합니다.
도매 소프트웨어의 기능 모델은 다음과 같습니다. 아래 그림은 최상위 DFD를 보여줍니다. 소프트웨어를 단일 프로세스로 보여주고 그와 상호 작용하는 행위자를 보여줍니다.
시스템의 배우는-
- Customers
- Salesperson
- Proprietor
다음 레벨 DFD에서는 다음 그림과 같이 시스템의 주요 프로세스가 식별되고 데이터 저장소가 정의되며 프로세스와 행위자와의 상호 작용 및 데이터 저장소가 설정됩니다.
시스템에서 세 가지 프로세스를 식별 할 수 있습니다.
- 고객 등록
- 프로세스 판매
- 선물 확인
필요한 데이터 저장소는-
- 고객의 세부 사항
- 판매 세부 정보
- 선물 정보
다음 그림은 고객 등록 프로세스의 세부 사항을 보여줍니다. 여기에는 세부 정보 확인, C_Code 생성 및 고객 세부 정보 업데이트의 세 가지 프로세스가 있습니다. 고객의 세부 사항을 입력하면 확인됩니다. 데이터가 올 바르면 C_Code가 생성되고 데이터 저장소 Customer Details가 업데이트됩니다.
다음 그림은 선물 확인 프로세스의 확장을 보여줍니다. 여기에는 총 판매 찾기 및 선물 코인 유형 결정의 두 가지 프로세스가 있습니다. 총 매출 찾기 프로세스는 각 고객에 해당하는 연간 총 매출을 계산하고 데이터를 기록합니다. 이 기록과 소유자의 결정을 입력으로 받아 선물 코인 결정 유형 프로세스를 통해 선물 코인이 할당됩니다.
DFD의 장단점
장점 | 단점 |
---|---|
DFD는 시스템의 경계를 나타내므로 시스템 내의 외부 개체와 프로세스 간의 관계를 나타내는 데 유용합니다. | DFD는 만드는 데 오랜 시간이 걸리며 실제 목적으로는 불가능할 수 있습니다. |
사용자가 시스템에 대한 지식을 갖도록 도와줍니다. | DFD는 시간에 따른 동작에 대한 정보를 제공하지 않습니다. 즉, 변환이 완료되는시기를 지정하지 않습니다. |
그래픽 표현은 프로그래머가 시스템을 개발하기위한 청사진 역할을합니다. | 그들은 계산의 빈도 나 계산 이유에 대해 어떤 빛도 던지지 않습니다. |
DFD는 시스템 프로세스에 대한 자세한 정보를 제공합니다. | DFD 준비는 상당한 전문 지식이 필요한 복잡한 프로세스입니다. 또한 비전문가도 이해하기 어렵습니다. |
시스템 문서의 일부로 사용됩니다. | 준비 방법은 주관적이며 부정확 할 수있는 충분한 범위를 남깁니다. |
개체, 동적 및 기능 모델 간의 관계
객체 모델, 동적 모델 및 기능 모델은 완전한 객체 지향 분석을 위해 서로 보완 적입니다.
객체 모델링은 객체 측면에서 소프트웨어 시스템의 정적 구조를 개발합니다. 따라서 시스템의 "실행자"를 보여줍니다.
동적 모델링은 외부 이벤트에 대한 응답으로 객체의 시간적 동작을 개발합니다. 개체에 대해 수행 된 작업 순서를 보여줍니다.
기능 모델은 시스템이 수행해야하는 작업에 대한 개요를 제공합니다.
기능 모델 및 개체 모델
객체 모델 측면에서 기능 모델의 네 가지 주요 부분은 다음과 같습니다.
Process − 프로세스는 구현해야하는 객체의 방법을 의미합니다.
Actors − 액터는 객체 모델의 객체입니다.
Data Stores − 이들은 개체 모델의 개체 또는 개체의 속성입니다.
Data Flows− 행위자와의 데이터 흐름은 객체에 대한 작업을 나타냅니다. 데이터 저장소를 오가는 데이터 흐름은 쿼리 또는 업데이트를 나타냅니다.
기능적 모델 및 동적 모델
동적 모델은 작업이 수행되는시기를 나타내며 기능적 모델은 작업이 수행되는 방식과 필요한 인수를 나타냅니다. 액터는 활성 개체이므로 동적 모델은 작동시기를 지정해야합니다. 데이터 저장소는 수동 개체이며 업데이트 및 쿼리에만 응답합니다. 따라서 동적 모델은 작동시기를 지정할 필요가 없습니다.
개체 모델 및 동적 모델
동적 모델은 개체의 상태와 이벤트 발생시 수행 된 작업 및 후속 상태 변경을 보여줍니다. 변경 결과로 개체의 상태가 개체 모델에 표시됩니다.