티스토리 뷰

별별 패턴이 다 있군요 😀

 

아키텍처 패턴

마스터-슬레이브 패턴 (Master-Slave Pattern)

  • 마스터 컴포넌트에서 슬레이브 컴포넌트로 작업을 분할한 후 슬레이브 컴포넌트에서 처리된 결과물을 다시 돌려받은 방식으로 작업을 수행한다.
  • 마스터 컴포넌트는 모든 직업의 주체이고, 슬레이브 컴포넌트는 마스터 컴포넌트의 지시에 따라 작업을 수행하여 결과를 반환한다.
  • 장애 허용 시스템과 병렬 컴퓨팅 시스템에서 주로 활용된다.

 

브로커 패턴 (Broker Pattern)

  • 사용자가 원하는 서비스와 특성을 브로커 컴포넌트에 요청하면 브로커 컴포넌트가 요청에 맞는 컴포넌트와 사용자를 연결해 준다.
  • 원격 서비스 호출에 응답하는 컴포넌트들이 여러 개 있을 때 적합한 패턴이다.
  • 분산 환경 시스템에서 주로 활용된다.

 

피어-투-피어 패턴 (Peer-To-Peer Pattern)

  • 피어를 하나의 컴포넌트로 간주하며, 각 피어는 서비스를 호출하는 클라이언트가 될 수도, 서비스를 제공하는 서버가 될 수도 있다.피어-투-피어 패턴에서 클라이언트와 서버는 전형적인 멀티스레딩 방식을 사용한다.

 

이벤트-버스 패턴 (Event-Bus Pattern)

  • 소스가 특정 채널에 이벤트 메시지를 발행하면 해당 채널을 구독한 리스너들이 메시지를 받아 이벤트를 처리하는 방식이다.
  • 이벤트를 생성하는 소스, 수행하는 리스너, 통로인 채널, 채널들을 관리하는 버스가 4가지 주요 컴포넌트이다.

 

블랙보드 패턴 (Blackboard Pattern)

  • 모든 컴포넌트들이 공유 데이터 저장소와 블랙보드 컴포넌트에 접근이 가능한 형태로, 컴포넌트들은 검색을 통해 블랙보드에서 원하는 데이터를 찾을 수 있다.
  • 해결책이 명확하지 않은 문제를 처리하는데 유용한 패턴이다.
  • 음성 인식, 차량 식별, 신호 해석 등에 주로 활용된다.

 

인터프리터 패턴 (Interpreter Pattern)

  • 프로그램 코드의 각 라인을 수행하는 방법을 지정하고, 기호마다 클래스를 갖도록 구성된다.
  • 특정 언어로 작성된 프로그램 코드를 해석하는 컴포넌트를 설계할 때 사용된다.

결합도(Coupling)

      결합도 약함                       ->                      결합도 강함

자료 결합도 < 스탬프 결합도 < 제어 결합도 < 외부 결합도 < 공통 결합도 < 내용 결합도

 

자료 결합도 (Data Coupling)

모듈 간의 인터페이스가 자료 요소로만 구성될 때의 결합도

어떤 모듈이 다른 모듈을 호출하면서 매개 변수나 인수로 데이터를 넘겨주고 호출받은 모듈은 받은 데이터에 대한 처리 결과를 다시 돌려주는 방식이다.

모듈 간의 내용을 전혀 알 필요가 없는 상태로서 한 모듈의 내용을 변경하더라도 다른 모듈에는 전혀 영향을 미치지 않는 가장 바람직한 결합도이다.

 

스탬프 결합도 (Stamp Coupling)

모듈 간의 인터페이스로 배열이나 레코드 등의 자료 구조가 전달될 때의 결합도

두 모듈이 동일한 자료 구조를 조회하는 경우의 결합도, 자료 구조의 어떠한 변화, 즉 포맷이나 구조의 변화는 그것을 조회하는 모든 모듈 및 변화되는 필드를 실제로 조회하지 않는 모듈에까지도 영향을 미치게 된다.

 

제어 결합도 (Control Coupling)

어떤 모듈이 다른 모듈 내부의 논리적인 흐름을 제어하기 위해 제어 신호를 이용하여 통신하거나 제어 요소(Function Code, Switch, Tag, Flag)를 전달하는 결합도

한 모듈이 다른 모듈의 상세한 처리 절차를 알고 있어 이를 통제하는 경우나 처리 기능이 두 모듈에 분리되어 설계된 경우에 발생한다.

하위 모듈에서 상위 모듈로 제어 신호가 이동하여 하위 모듈이 상위 모듈에게 처리 명령을 내리는 권리 전도현상이 발생하게 된다.

 

외부 결합도 (External Coupling)

어떤 모듈에서 선언한 데이터를 외부의 다른 모듈에서 참조할 때의 결합도이다.

참조되는 데이터의 범위를 각 모듈에서 제한할 수 있다.

 

공통(공유) 결합도 (Common Coupling)

공유되는 공통 데이터 영역을 여러 모듈이 사용할 때의 결합도이다.

공통 데이터 영역의 내용을 조금만 변경하더라도 이를 사용하는 모든 모듈에 영향을 미치므로 모듈의 독립성을 약하게 만든다.

 

내용 결합도 (Content Coupling)

한 모듈이 다른 모듈의 내부 기능 및 그 내부 자료를 직접 참조하거나 수정할 때의 결합도

한 모듈에서 다른 모듈의 내부로 제어가 이동하는 경우에도 내용 결합도에 해당된다.


응집도(Cohesion)

응집도 강함              <-               응집도 약함
기능적 응집도 > 순차적 응집도 > 교환적 응집도 > 절차적 응집도 > 시간적 응집도 > 논리적 응집도 > 우연적 응집도

 

기능적 응집도 (Funtional Cohesion)

모듈 내부의 모든 기능 요소들이 단일 문제와 연관되어 수행될 경우의 응집도

 

순차적 응집도 (Sequential Cohesion)

모듈 내 하나의 활동으로부터 나온 출력 데이터를 그다음 활동의 입력 데이터로 사용할 경우의 응집도

 

교환적 응집도 (Communication Cohesion)

동일한 입력과 출력을 사용하여 서로 다른 기능을 수행하는 구성 요소들이 모였을 경우의 응집도

 

절차적 응집도 (Procedural Cohesion)

모듈이 다수의 관련 기능을 가질 때 모듈 안의 구성 요소들이 그 기능을 순차적으로 수행할 경우의 응집도

 

시간적 응집도 (Temporal Cohesion)

특정 시간에 처리되는 몇 개의 기능을 모아 하나의 모듈로 작성할 경우의 응집도

 

논리적 응집도 (Logical Cohesion)

유사한 성격을 갖거나 특정 형태로 분류되는 처리 요소들로 하나의 모듈이 형성되는 경우의 응집도

 

우연적 응집도 (Coincidental Cohesion)

모듈 내부의 각 구성 요소들이 서로 관련 없는 요소로만 구성된 경우의 응집도


응집도는 강하고 결합도는 약해야 좋은 설계다!

728x90
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/07   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
글 보관함