Files
2nd/01_Archive/2026-04-20/응집도와 결합도 (Cohesion and Coupling).md
T

5.8 KiB

id, category, confidence_score, tags, last_reinforced, github_commit
id category confidence_score tags last_reinforced github_commit
P-REINFORCE-AUTO-AECECF 10_Wiki/💡 Topics/Programming & Language 0.90
auto-reinforced
2026-04-20 [P-Reinforce] Continuous Worker - 응집도와 결합도 (Cohesion and Coupling)

응집도와 결합도 (Cohesion and Coupling)

📌 한 줄 통찰 (The Karpathy Summary)

**응집도(Cohesion)**는 모듈 내부의 요소들이 하나의 명확한 목적을 위해 얼마나 밀접하게 관련되어 있는지를 측정하는 척도이며, **결합도(Coupling)**는 모듈 간의 상호 의존성 정도를 나타내는 척도이다 [1], [2], [3]. "관심사의 분리(SoC)" 원칙을 소프트웨어에 적용하는 핵심 과정은 결합도를 낮추고(Loose Coupling) 응집도를 높이는(High Cohesion) 것이다 [4], [5]. 이를 달성함으로써 시스템의 복잡성을 줄이고 가독성, 유지보수성, 테스트 가능성을 비약적으로 향상시킬 수 있다 [6], [7], [8].

📖 구조화된 지식 (Synthesized Content)

1. 응집도와 결합도의 개념

  • 응집도(Cohesion): 모듈이나 클래스 내의 요소들이 직무의 집합이나 세부사항 측면에서 얼마나 유사하고 단일한 기능에 집중하고 있는지를 의미한다 [4], [2]. 이상적인 형태인 '기능적 응집'부터 순차적, 논리적, 시간적, 절차적, 그리고 가장 낮은 수준인 '우발적 응집'으로 분류할 수 있다 [2].
  • 결합도(Coupling): 한 모듈이 시스템의 나머지 부분이나 다른 모듈에 얼마나 의존하는지를 나타낸다 [9], [3]. 가장 강한 형태인 '내용 결합'부터 공통, 외부, 제어, 스탬프, 그리고 가장 이상적이고 약한 형태인 '자료 결합' 순으로 나뉜다 [3].

2. 관심사의 분리(SoC)와의 관계

  • 관심사의 분리가 성공적으로 이루어졌는지를 판단하는 정량적, 정성적 핵심 척도가 바로 응집도와 결합도이다 [1].
  • 내부의 결속력(상호작용)은 극대화하고 외부의 간섭은 최소화하는 것이 관심사 분리의 공학적 지향점이다 [10]. 이를 수학적 비유로 표현하면, 설계 품질은 모듈 내부의 상호작용 총합을 모듈 외부와의 상호작용 총합으로 나눈 값에 비례한다 [10].
  • 만약 코드의 알고리즘 논리를 파악할 때 여러 기능이나 모듈 사이를 빈번하게 뛰어다니며 확인해야 한다면, 이는 응집도가 낮다는 신호이며 흔히 **'스파게티 코드(Spaghetti code)'**라 불리는 관리 불능 상태를 낳게 된다 [11], [12], [1].

3. 높은 응집도와 낮은 결합도의 주요 이점

  • 가독성 및 유지보수성 향상: 각 모듈이 명확한 API와 단일 책임을 갖게 되어 프로그램의 동작을 파악하기 쉬워진다 [6], [7]. 또한 특정 기능을 수정할 때 다른 모듈에 미치는 영향이 국소화되어 부작용 발생을 막을 수 있다 [12], [7], [8].
  • 재사용성 극대화(DRY 원칙): 특정 역할에 대해 타 모듈과 독립된 코드는 현재 시스템뿐만 아니라 다른 프로젝트에서도 쉽게 재사용할 수 있어 전체적인 개발 비용을 절감한다 [6], [7], [8].
  • 테스트 용이성 확보: 모듈이 다른 모듈에 거의 의존하지 않으므로, 전체 애플리케이션 환경을 구동할 필요 없이 가짜 데이터(Mock, 페이크 등)로 외부 환경을 대체하여 격리된 독립 테스트(단위 테스트)가 가능해진다 [6], [12], [7], [8].
  • 동시 개발의 효율성 향상: 역할과 경계가 명확하게 분리되면, 여러 엔지니어가 서로의 코드에 간섭하지 않고 독립적으로 병렬 개발을 진행할 수 있다 [6], [12].

4. 결합도를 낮추기 위한 전략

  • 모듈 간 상호작용을 추상화된 인터페이스를 통해 정의하거나, 필요한 객체를 외부에서 주입받는 의존성 주입(Dependency Injection), 직접 호출 대신 간접적으로 통신하는 이벤트 기반 아키텍처를 활용하면 결합도를 효과적으로 줄일 수 있다 [10], [13]. 또한 내부 구현을 캡슐화하고 데이터 구조를 단순화하는 것 역시 의존성을 낮추는 주요 전략이다 [13].

⚠️ 모순 및 업데이트 (Contradictions & RL Update)

  • 과거 데이터와의 충돌: 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
  • 정책 변화: Programming & Language 분야의 자동 자산화 수행.

🔗 지식 연결 (Graph)


Last updated: 2026-04-18

  • Raw Source: 00_Raw/2026-04-20/응집도와 결합도 (Cohesion and Coupling).md