모듈이란?
- 모듈화를 통해 분리된 시스템의 각 기능들로, 서브루틴, 서브시스템, 소프트웨어 내의 프로그램, 작업 단위 등과 같은 의미로 사용됩니다.
- 독립성을 높이려면 모듈의 결합도는 약하게, 응집도는 강하게, 모듈의 크기는 작게 만들어야 합니다.
결합도 (Coupling)?
- 모듈 간에 상호의존 하는 정도 또는 두 모듈간의 연관 관계를 말한다.
- (강) 내용 결합도 - 공통 결합도 - 외부 결합도 - 제어 결합도 - 스탬프 결합도 - 자료 결합도 (약)
- 내용 결합도: 모듈간 내부 자료나 기능을 직접 참조하거나 수정할 때의 결합도
- 공통(공유) 결합도: 공유되는 공통 데이터 영역을 여러 모듈이 사용할 때의 결합도
- 외부 결합도: 어떤 모듈에서 선언된 데이터 (변수)를 다른 모듈에서 사용할 때의 결합도
- 제어 결합도: 한 모듈이 다른 모듈의 상세한 처리 절차를 알고 있어 이를 통제하는 경우나 처리 기능이 두 모듈에 분리되어 설계된 경우의 결합도
- 스탬프 결합도: 두 모듈이 동일한 자료 구조(복합 데이터) 를 조회하는 경우의 결합도
- 자료 결합도: 어떤 모듈이 다른 모듈을 호출하면서 매개 변수나 인수로 데이터를 넘겨주고, 호출 받은 모듈은 받은 데이터에 대한 처리 결과를 다시 돌려주는 방식의 결합도
응집도 (Cohesion)?
- 정보 은닉 개념을 확장한 것, 명령어나 호출문 등 모듈의 내부 요소들이 서로 관련되어 있는 정도, 즉 모듈이 독립적인 기능으로 정의되어 있는 정도를 의미한다.
- (강) 기능적 - 순차적 - 통신적 - 절차적 - 시간적 - 논리적 - 우연적 (약)
- 기능적 응집도: 모듈 내부의 모든 기능 요소들이 단일 문제와 연관되어 수행될 경우의 응집도
- 순차적 응집도: 모듈 내 하나의 활동으로부터 나온 출력 데이터를 그다음 활동의 입력 데이터로 사용할 경우의 응집도(한 활동의 출력이 다음 활동의 입력으로 사용)
- 통신적 응집도: 동일한 입력과 출력을 사용하여 서로 다른 기능을 수행하는 구성 요소들이 모였을 경우의 응집도 (한 모듈에서 동일한 데이터를 기반으로 데이터 검증, 데이터 처리, 로그 기록 등 여러 기능을 수행)
- 절차적 응집도: 모듈이 다수의 관련 기능을 가질 때 모듈 안의 구성 요소들이 그 기능을 순차적으로 수행할 경우의 응집도
- 시간적 응집도: 특정 시간에 처리되는 몇 개의 기능을 모아 하나의 모듈로 작성할 경우의 응집도
- 논리적 응집도: 유사한 성격을 갖거나 특정 형태로 분류되는 처리 요소들로 하나의 모듈이 형성되는 경우의 응집도
- 우연적 응집도: 모듈 내의 요소들이 아무런 관련없이 우연히 놓여 있는 경우의 응집도