Wikification: Migrate 128 software engineering topics from out_wiki with P-Reinforce v3.0 standards
This commit is contained in:
@@ -0,0 +1,15 @@
|
||||
# [[Program Dependence Graph]]
|
||||
|
||||
## 📌 Brief Summary
|
||||
Program Dependence Graph(프로그램 의존성 그래프, PDG)는 코드 내의 데이터 및 제어 의존성(data and control dependencies)을 명시적으로 표현하는 모델입니다 [1]. 이는 표현식이나 메서드와 같은 두 코드 조각 간의 방향성 있는 관계를 나타내며, 리팩토링 대상이 되는 프로그램의 잠재적 문제를 탐지하기 위한 정적 프로그램 분석(Static program analysis) 등에 활용됩니다 [1, 2]. 개별 PDG들 간의 프로시저 호출을 연결하면 시스템 전체의 의존성을 나타내는 시스템 의존성 그래프(System Dependence Graph)로 확장하여 분석할 수 있습니다 [1].
|
||||
|
||||
## 📖 Core Content
|
||||
* **의존성의 정의와 종류:** 소프트웨어에서 의존성이란 코드의 두 부분 사이의 방향성 있는 관계를 의미합니다 [2]. 여기에는 값의 정의와 사용 사이에서 발생하는 '데이터 의존성(data dependencies)'과 함수의 선언부와 실제 호출되는 위치 사이의 '호출 의존성(call dependencies)' 등이 포함됩니다 [2].
|
||||
* **정적 분석 도구로서의 역할:** PDG는 유효하지만 표준 이하(substandard)인 프로그램의 구조적 문제를 탐지하기 위한 정적 분석 기법의 핵심적인 표현 도구로 사용됩니다 [1].
|
||||
* **시스템 의존성 그래프(System Dependence Graph)로의 확장:** PDG들 사이의 프로시저 호출 관계를 표현하기 위해 시스템 의존성 그래프가 사용됩니다 [1]. 마이크로소프트(Microsoft)의 MaX와 같은 자동화 도구는 함수 수준(호출, 임포트, 익스포트 등)에서 이러한 의존성 정보를 추적하여 시스템 전반의 의존성 그래프를 생성하며, 이를 변경 영향 분석(change impact analysis) 및 통합 테스트에 활용합니다 [2].
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
소스에 관련 정보가 부족합니다.
|
||||
|
||||
---
|
||||
*Last updated: 2026-05-03*
|
||||
Reference in New Issue
Block a user