목차
📌 모듈은 모듈화를 통해 분리된 시스템의 각 기능들로, 서브루틴, 서브시스템, 소프트웨어 내의 프로그램, 작업 단위 등과 같은 의미로 사용된다.
💡 모듈화(Modularity) ? 모듈화는 소프트웨어의 성능을 향상시키거나 시스템의 수정 및 재사용 유지 관리 등이 용이하도록 시스템의 기능들을 모듈 단위로 분해하는 것을 의미한다.
- 루틴(Routine) : 기능을 가진 명령들의 모임
- 메인 루틴(Main Routine) : 프로그램 실행의 큰 줄기가 되는 것
- 서프루틴(Subroutine) : 메인 루틴에 의해 필요할 때 마다 호출되는 루틴
💡 서브시스템(Subsystem) ? 서브시스템은 시스템을 구성하는 요소의 하나로, '단위시스템'이라고도 불리며, 서브시스템 자체로도 하나의 시스템에 필요한 요소들을 갖추고 있다. 예를 들어 메인 스시템이 '통합 경영정보 시스템'이라면 여기에 속하는 서브시스템으로 '영업 관리 시스템', '생산관리 시스템', '인사관리 시스템' 등이 있을 수 있다.
📌 결합도는 모듈 간에 상호 의존하는 정도 또는 두 모듈 사이의 연관 관계를 의미한다.
자료 결합도 (Data Coupling) |
- 모듈 간의 인터페이스가 자료 요소로만 구성될 때의 결합도이다. - 어떤 모듈이 다른 모듈을 호출하면서 매개 변수나 인수로 데이터를 넘겨주고 호출 받은 모듈은 받은 데이터에 대한 처리 결과를 다시 돌려주는 방식이다. - 모듈간의 내용을 전혀 알 필요가 없는 상태로서 한 모듈의 내용을 변경하더라도 다른 모듈에는 전혀 영향을 미치지 않는 가장 바람직한 결합도이다. |
스템프(검인) 결합도 (Stamp Coupling) |
- 모듈 간의 인터페이스로 배열이나 레코드 등의 자료 구조가 전달될 때의 결합도이다. - 두 모듈이 동일한 자료 구조를 조회하는 경우의 결합도이며, 자료 구조의 어떠한 변화, 즉 포멧이나 구조의 변화는 그것을 조회하는 모든 모듈 및 변화되는 필드를 실제로 조회 하지 않는 모듈에까지도 영향을 미치게 된다. |
제어 결합도 (Control Coupling) |
- 어떤 모듈이 다른 모듈 내부의 논리적인 흐름을 제어하기 위해 제어 신호를 이용하여 통신하거나 제어 요소(Function Code, Switch, Tag, Flag)를 전달하는 결합도이다. - 한 모듈이 다른 모듈의 상세한 처리 절차를 알고 있어 이를 통제하는 경우나 처리 기능이 두 모듈에 분리되어 설계된 경우에 발생한다. - 하위모듈에서 상위 모듈로 제어 신호가 이동하여 하위 모듈이 상위 모듈에게 처리 명령을 내리는 권리 전도현상이 발생하게 된다. |
외부 결합도 (External Coupling) |
- 어떤 모듈에서 선언한 데이터(변수)를 외부의 다른 모듈에서 참조할 때의 결합도이다. - 참조되는 데이터의 범위를 각 모듈에서 제한할 수 있다. |
공통(공유) 결합도 (Common Couplig) |
- 공유되는 공통 데이터 영역을 여러 모듈이 사용할 때의 결합도이다. - 공통 데이터 영역의 내용을 조금만 변경하더라도 이를 사용하는 모든 모듈에 영향을 미치므로 모듈의 독립성을 약하게 만든다. |
내용 결합도 (Content Coupling) |
- 한 모듈이 다른 모듈의 내부 기능 및 그 내부 자료를 직접 참조하거나 수정할 때의 결합도이다. - 한 모듈에서 다른 모듈의 내부로 제어가 이동하는 경우에도 내용 결합도에 해당된다. |
📌 응집도는 정보 은닉 개념을 확장한 것으로, 명령어나 호출문 등 모듈의 내부 요소들의 서로 관련되어 있는 정도, 즉 모듈이 독립적인 기능으로 정의되어 있는 정도를 의미한다.
기능적 응집도 (Functional Cohesion) |
모듈 내부의 모든 기능 요소들이 단일 문제와 연관되어 수행될 경우의 응집도 |
순차적 응집도 (Sequential Cohesion) |
모듈 내 하나의 활동으로부터 나온 출력 데이터를 그 다음 활동의 입력 데이터로 사용할 경우의 응집도 |
교환(통신) 응집도 (Communication Cohesion) |
동일한 입력과 출력을 사용하여 서로 다른 기능을 수행하는 구성 요소들이 모였을 경우의 응집도 |
절차적 응집도 (Procedual Cohesion) |
모듈이 다수의 관련 기능을 가질 때 모듈 안의 구성 요소들이 그 기능을 순차적으로 수행할 경우의 응집도 |
시간적 응집도 (Temporal Cohesion) |
특정 시간에 처리되는 몇 개의 기능을 모아 하나의 모듈로 작성할 경우의 응집도 |
논리적 응집도 (Logical Cohesion) |
유사한 성격을 갖거나 특정 형태로 분류되는 처리 요소들로 하나의 모듈이 형성되는 경우의 응집도 |
우연적 응집도 (Coincidental Cohesion) |
모듈 내부의 각 구성 요소들이 서로 관련 없는 요소로만 구성된 경우의 응집도 |
💡 팬인 / 팬아웃은 모듈에 들어오면(In) 팬인, 모듈에서 나가면(Out) 팬아웃이다.
💡 단일 장애점(SPOF, Single Point Of Failure) : 단일 장애점은 시스템의 구성 요소 중 동작하지 않으면 전체 시스템이 중단되어 버리는 요소를 의미하며, 단일 실패점 이라고도 한다.
📌 N-S 차트는 논리의 기술에 중점을 둔 도형을 이용한 표현 방법으로 박스 다이어그램, Chapin Chart 라고도 한다.
📌 애플리케이션 설계 - 코드 (0) | 2024.01.25 |
---|---|
📌 애플리케이션 설계 - 공통 모듈 (2) | 2024.01.24 |
📌 애플리케이션 설계 - 객체지향 분석 및 설계 (2) | 2024.01.23 |
📌 애플리케이션 설계 - 객체 지향(Object-Oriented) (0) | 2024.01.22 |
📌 애플리케이션 설계 - 아키텍처 패턴 (2) | 2024.01.18 |