Initial Commit: Reinforced Knowledge Wiki v1.0 - Pure Origin
This commit is contained in:
@@ -0,0 +1,40 @@
|
||||
---
|
||||
id: P-REINFORCE-AUTO-0538AE
|
||||
category: "[[10_Wiki/💡 Topics/Programming & Language]]"
|
||||
confidence_score: 0.90
|
||||
tags: [auto-reinforced]
|
||||
last_reinforced: 2026-04-20
|
||||
github_commit: "[P-Reinforce] Continuous Worker - 의존성 주입 (DI)"
|
||||
---
|
||||
|
||||
# [[의존성 주입 (DI)]]
|
||||
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
> 의존성 주입(DI, Dependency Injection)은 모듈이나 클래스가 필요로 하는 의존성을 내부에서 직접 생성하지 않고 외부에서 제공(주입)받도록 하는 소프트웨어 설계 기법입니다 [1, 2]. 이는 객체 지향 프로그래밍의 주요 원칙인 의존성 역전 원칙(DIP)을 구현하는 대표적인 방법으로 사용됩니다 [3]. 컴포넌트 간의 결합도를 낮추고 모듈성을 높여 시스템의 유지보수성과 테스트 용이성을 크게 향상시키는 것이 주된 목적입니다 [4, 5].
|
||||
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **작동 원리 및 목적:**
|
||||
의존성 주입은 상위 계층이 하위 계층의 인스턴스를 직접 생성하는 대신, 외부 소스로부터 의존성을 주입받도록 하여 느슨한 결합(Loose Coupling)을 촉진합니다 [1, 2]. 이를 통해 핵심 로직을 변경하지 않고도 종속성을 관리하거나 특정 구현체를 쉽게 교체할 수 있게 해줍니다 [4].
|
||||
|
||||
* **설계 원칙과의 관계:**
|
||||
DI는 주로 의존성 역전 원칙(DIP)을 실현하는 수단으로 활용되며, 모듈들이 구체적인 도구가 아닌 추상화(인터페이스)에 의존하도록 구성 요소들을 런타임에 연결합니다 [3, 6]. 또한, 관심사의 분리(SoC)를 달성하여 시스템의 여러 기능이 서로 얽히지 않고 독립적으로 동작하도록 돕는 핵심 전략이기도 합니다 [5, 7, 8].
|
||||
|
||||
* **주요 이점:**
|
||||
의존성 주입을 활용하면 모듈 간의 결합도가 낮아져 시스템 부품 간 독립성이 보장되고 재사용률이 높아집니다 [5]. 특히 테스트 용이성이 크게 향상되는데, 모듈이 외부 구현에 얽매이지 않기 때문에 테스트 시 실제 의존성 대신 목(Mock) 객체나 가짜 데이터 소스로 교체하여 다양한 시나리오를 쉽게 시뮬레이션하고 검증할 수 있습니다 [1, 4, 9].
|
||||
|
||||
* **아키텍처 및 프레임워크에서의 활용:**
|
||||
계층형 아키텍처나 클린 아키텍처 등에서 계층 간 결합을 끊기 위해 적극적으로 사용됩니다 [1, 6, 7]. Java의 Spring이나 ASP.NET Core와 같은 프레임워크는 내장된 DI 컨테이너를 제공하여 컴포넌트 분리를 수월하게 돕습니다 [10]. 다만 클린 아키텍처의 관점에서는 의존성 주입 프레임워크를 사용하더라도 시스템 전반이 프레임워크에 종속되는 것을 막기 위해, 실제 의존성 주입 작업은 가장 낮은 수준의 정책인 '메인(Main) 컴포넌트'에서 이루어져야 한다고 권장합니다 [11]. 이후에는 DI 프레임워크 없이도 일반적인 방식으로 의존성이 분배되어야 합니다 [11].
|
||||
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & RL Update)
|
||||
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
|
||||
- **정책 변화:** Programming & Language 분야의 자동 자산화 수행.
|
||||
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** [[의존성 역전 원칙 (DIP)]], [[관심사의 분리 (SoC)]], [[느슨한 결합 (Loose Coupling)]], [[모듈성 (Modularity)]]
|
||||
- **Projects/Contexts:** [[Spring Framework]], [[ASP.NET Core]], [[클린 아키텍처 (Clean Architecture)]], [[계층형 아키텍처 (Layered Architecture)]]
|
||||
- **Contradictions/Notes:** 소스에 따르면, 의존성 주입 프레임워크의 편리함에도 불구하고, 시스템이 프레임워크 자체에 강하게 결합되는 것을 피하기 위해 메인(Main) 컴포넌트 내부로 주입 책임을 철저히 제한해야 한다고 지적합니다 [11].
|
||||
|
||||
---
|
||||
*Last updated: 2026-04-18*
|
||||
- Raw Source: [[00_Raw/2026-04-20/의존성 주입 (DI).md]]
|
||||
---
|
||||
Reference in New Issue
Block a user