68 lines
7.7 KiB
Markdown
68 lines
7.7 KiB
Markdown
---
|
|
id: P-REINFORCE-WIKI-D8B40C28
|
|
category: "10_Wiki/💡 Topics/02_Architecture_Principles"
|
|
confidence_score: 0.95
|
|
tags: ['design-pattern', 'software-architecture-pattern', 'creational,-structural,-and-behavioral-patterns', 'software-architecture-pattern', 'anti-patterns', 'architecture-principles']
|
|
last_reinforced: 2026-05-02
|
|
---
|
|
|
|
# [[Design Pattern]]
|
|
|
|
## 📌 Brief Summary
|
|
디자인 패턴(Design Pattern)은 소프트웨어 컴포넌트나 모듈 내에서 반복적으로 발생하는 설계 문제에 대해 재사용 가능한 소규모의 표준화된 해결책입니다 [1, 2]. 이는 전체 시스템의 거시적인 구조를 정의하는 소프트웨어 아키텍처 패턴과 달리, 단일 모듈이나 클래스 내의 미시적인 설계 결정, 개체의 행동 및 관계를 다룹니다 [1, 3]. 대표적인 예로는 싱글톤(Singleton), 팩토리(Factory), 전략(Strategy), 옵저버(Observer) 패턴 등이 있습니다 [2, 4].
|
|
|
|
## 📖 Core 기Content
|
|
* **아키텍처 패턴과의 구조적 차이:**
|
|
아키텍처 패턴이 전체 시스템의 고수준 구조, 컴포넌트 조직, 상호작용 및 전반적인 레이아웃을 정의하는 반면, 디자인 패턴은 개별 컴포넌트나 클래스 내부의 구조적, 행위적 측면에 초점을 맞춥니다 [1-3]. 즉, 소프트웨어 아키텍처 패턴은 대규모 컴포넌트를 다루지만, 디자인 패턴은 객체 생성, 상호작용, 행동과 같은 세부적인 미시적 설계(micro-level design) 결정을 다룹니다 [1, 3, 4].
|
|
|
|
* **목적과 특징:**
|
|
디자인 패턴은 시스템 구현 시 반복되는 문제에 대해 검증된 재사용 가능한 해결책을 제공합니다 [2, 5]. 이를 통해 코드의 재사용성, 가독성, 그리고 유지보수성을 향상시키는 역할을 합니다 [1, 2]. 디자인 패턴의 범위는 개별 컴포넌트로 좁게 제한되며, 아키텍처 패턴이 정의한 전체적인 프레임워크와 구조에 기여하는 역할을 합니다 [1, 2]. 문서화 측면에서도 아키텍처 패턴이 고수준 설계 문서나 아키텍처 다이어그램을 포함하는 반면, 디자인 패턴은 상세 설계 명세서나 UML 다이어그램을 주로 수반합니다 [2].
|
|
|
|
* **설계의 국소성 기준 (Locality Criterion):**
|
|
아키텍처적 설계와 세부 설계(디자인 패턴 등)를 구분하는 한 가지 시도로 '국소성 기준(Locality Criterion)'이 있습니다 [6]. 이 기준에 따르면, 특정 소프트웨어 설계 조건이 국소적이지 않을 때(non-local) 아키텍처적이라고 정의하며, 프로그램이 해당 조건을 위반하도록 확장될 수 있다면 그것은 아키텍처 설계에 해당합니다 [6]. 디자인 패턴은 이 기준에 비추어 볼 때 더 국소적인 성격을 지닙니다 [6].
|
|
|
|
* **디자인 패턴의 주요 분류:**
|
|
디자인 패턴은 소프트웨어 구축 및 구현 문제를 해결하기 위해 크게 생성적(Creational), 구조적(Structural), 행위적(Behavioral) 패턴으로 분류될 수 있습니다 [7].
|
|
|
|
## ⚖️ Trade-offs & Caveats
|
|
소스에 관련 정보가 부족합니다. (제공된 소스는 아키텍처 패턴의 장단점은 상세히 설명하고 있으나, 디자인 패턴 자체를 적용했을 때 발생할 수 있는 제약 사항, 부작용 또는 반대 급부에 대한 구체적인 내용은 포함하고 있지 않습니다.)
|
|
|
|
## 🔗 Knowledge Connections
|
|
|
|
### Related Concepts
|
|
|
|
#### [구조적 차원 (Structural Dimension)]
|
|
- [[Software Architecture Pattern]]
|
|
- 연결 이유: 디자인 패턴이 개별 컴포넌트 내부의 미시적 설계를 다루는 반면, 소프트웨어 아키텍처 패턴은 시스템 전반의 거시적 구조를 정의하므로 두 개념은 상호 보완적이면서도 대비되는 핵심 개념입니다 [1, 2].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 마이크로 레벨의 디자인 패턴들이 어떻게 조합되어 매크로 레벨의 아키텍처 패턴(예: 계층형, 마이크로서비스)이 제공하는 큰 틀 내에서 작동하고 기여하는지 구조적 차이를 명확히 이해할 수 있습니다 [1, 2].
|
|
|
|
#### [분류 체계 (Classification)]
|
|
- [[Creational, Structural, and Behavioral Patterns]]
|
|
- 연결 이유: 디자인 패턴이 소프트웨어의 다양한 구현 문제를 해결하기 위해 채택하는 구체적인 분류 체계입니다 [7].
|
|
- 이 개념을 통해 더 깊게 이해할 수 있는 부분: 소프트웨어 구축 과정에서 객체 생성, 구조화, 동작 방식을 다루는 구체적인 방법론(예: 싱글톤, 팩토리, 옵저버 등)을 이해할 수 있습니다 [2, 4, 7].
|
|
|
|
### Deeper Research Questions
|
|
|
|
- 특정 아키텍처 패턴(예: 계층형 아키텍처) 내에서 디자인 패턴(예: 팩토리, 전략 패턴)은 구체적으로 어떻게 결합되어 코드의 재사용성과 유지보수성을 극대화하는가?
|
|
- 국소성 기준(Locality Criterion)을 적용할 때, 특정 디자인 패턴이 시스템 크기가 커지거나 구조가 변경됨에 따라 아키텍처적 결정으로 성격이 변질되는 경계는 어디인가?
|
|
- 싱글톤이나 옵저버와 같은 디자인 패턴들을 잘못 사용했을 때, 아키텍처 수준의 성능 저하(예: 병목 현상)로 이어질 수 있는 구체적인 메커니즘은 무엇인가?
|
|
- 객체 지향 프로그래밍 시대에 확립된 디자인 패턴들이 함수형 프로그래밍이나 서버리스(Serverless)와 같은 최신 클라우드 네이티브 환경에서도 여전히 유효한가?
|
|
- 마이크로 레벨의 디자인 패턴이 시스템의 거시적인 보안 취약점을 예방하거나 완화하는 데 직접적으로 기여할 수 있는 사례가 있는가?
|
|
|
|
### Practical Application Contexts
|
|
|
|
- **Implementation:** 개발자가 코딩 단계에서 개별 객체나 클래스의 생성을 관리하거나 컴포넌트 간의 특정 상호작용 문제를 해결할 때, 표준화된 해결책인 싱글톤, 팩토리 등의 디자인 패턴을 직접 적용합니다 [2, 4].
|
|
- **System Design:** 상세 시스템 설계 단계에서 개별 모듈 내의 구조적, 행위적 측면을 명확히 하기 위해 UML 다이어그램 및 상세 설계 사양서를 작성할 때 디자인 패턴이 활용됩니다 [2].
|
|
- **Operation / Maintenance:** 디자인 패턴을 통해 작성된 코드는 가독성이 높고 재사용이 쉬워져, 향후 시스템의 로직을 변경하거나 새로운 기능을 추가하는 유지보수 작업을 효율적으로 만듭니다 [1, 8].
|
|
- **Learning Path:** 시스템의 전체 구조인 아키텍처를 이해하는 과정에서, 더 작은 단위인 개별 모듈이 어떻게 조직되고 동작하는지(디자인)를 학습하는 것은 소프트웨어 공학의 기초를 다지는 필수 단계입니다 [1, 9].
|
|
- **My Project Relevance:** 개발 프로젝트 시 아키텍처 패턴(예: 클린 아키텍처, 계층형 아키텍처)이 정해진 테두리 안에서, 더욱 품질이 높고 버그가 적은 코드를 작성하기 위한 구체적인 코딩 전술로 활용될 수 있습니다 [10, 11].
|
|
|
|
### Adjacent Topics
|
|
|
|
- [[Software Architecture Pattern]]
|
|
- 확장 방향: 마이크로 레벨의 세부 설계에서 벗어나, 시스템 전반의 컴포넌트 상호작용, 성능, 확장성 등을 제어하는 매크로 레벨의 방법론으로 시야를 넓혀 학습을 확장할 수 있습니다 [1, 3, 12].
|
|
- [[Anti-patterns]]
|
|
- 확장 방향: 잘못된 아키텍처적 결정이나 설계 선택이 어떻게 시스템의 품질을 저하시키는지(예: 구조 침식 등)를 연구하여, 올바른 디자인 패턴 및 아키텍처 패턴 적용의 중요성을 역설적으로 이해하는 방향으로 확장할 수 있습니다 [13, 14].
|
|
|
|
---
|
|
*Last updated: 2026-05-02* |