feat: Wiki 지식 자산 업데이트 - UX Scenarios, Frontend, Game Design, Topics 추가 [2026-05-08]
This commit is contained in:
@@ -1,20 +1,33 @@
|
||||
---
|
||||
category: Unified
|
||||
id: wiki-2026-0508-ast-abstract-syntax-tree
|
||||
title: AST(Abstract Syntax Tree)
|
||||
category: 10_Wiki/Topics
|
||||
status: needs_review
|
||||
canonical_id: self
|
||||
aliases: []
|
||||
duplicate_of: none
|
||||
source_trust_level: A
|
||||
confidence_score: 0.92
|
||||
tags: [auto-consolidated, technical-documentation]
|
||||
title: [[AST(Abstract Syntax Tree)|AST(Abstract Syntax Tree]]
|
||||
last_updated: 2026-05-02
|
||||
raw_sources: []
|
||||
last_reinforced: 2026-05-08
|
||||
github_commit: pending
|
||||
inferred_by: Claude Opus 4.7 (auto-normalize 2026-05-08)
|
||||
tech_stack:
|
||||
language: unspecified
|
||||
framework: unspecified
|
||||
---
|
||||
|
||||
# [[AST(Abstract Syntax Tree)|AST(Abstract Syntax Tree]]
|
||||
|
||||
## 📌 Brief Summary
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
> AST(Abstract Syntax Tree, 추상 구문 트리)는 소스 코드를 파싱하여 프로그래밍 언어의 문법적 구조를 트리 형태로 표현한 데이터 구조입니다. 공백이나 들여쓰기 같은 표면적인 레이아웃 정보는 배제하고 본질적인 구문 특징과 알고리즘 구조만을 보존하는 것이 특징입니다 [1]. 주로 [[SAST|SAST]](정적 애플리케이션 보안 테스트), 린팅(Linting), 그리고 코드 작성자를 식별하는 코드 스타일로메트리(Code Stylometry) 분야에서 코드를 분석하는 핵심 기반으로 사용됩니다 [1, 2].
|
||||
|
||||
---
|
||||
|
||||
추상 구문 트리(AST, Abstract Syntax Tree)는 최신 AI 기반 코드 분석 및 리뷰 도구에서 코드베이스를 심층적으로 검사하기 위해 활용되는 핵심 기반 기술입니다 [1, 2]. CodeRabbit과 같은 도구에서 정적 애플리케이션 보안 테스트(SAST) 및 생성형 AI와 결합되어 코드의 런타임 버그를 탐지하고 시니어 엔지니어 수준의 피드백을 제공하는 데 사용됩니다 [3, 4]. 소스 데이터 내에는 AST의 기술적 구조나 파싱 원리에 대한 구체적인 정보가 부족합니다.
|
||||
|
||||
## 📖 Core Content
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
* **AST의 구조적 특징 및 CST와의 차이**
|
||||
AST는 소스 코드를 구문 분석(Parsing)하여 만들어지며, 컴파일러나 분석 도구가 코드를 이해하는 추상적인 뼈대 역할을 합니다 [1, 2]. 코드의 들여쓰기나 줄 바꿈 등 레이아웃 속성을 철저히 보존하는 CST(Concrete Syntax Tree)와 달리, AST는 이러한 레이아웃 특징을 무시합니다 [1, 3]. 따라서 코드를 포맷팅하거나 여백을 크게 수정하더라도 구문이 동일하다면 파싱 후 생성되는 AST의 구조는 변하지 않습니다 [3].
|
||||
|
||||
@@ -31,7 +44,7 @@ last_updated: 2026-05-02
|
||||
- **심층적 코드 리뷰 지원**: 단순한 텍스트나 구문 검사를 넘어, AST는 코드베이스의 맥락과 구조를 파악하여 심층적인 코드 리뷰를 수행할 수 있도록 돕습니다 [2].
|
||||
- *(소스에 관련 정보가 부족합니다: AST가 코드를 어떻게 노드 트리 형태로 변환하는지, 파서(Parser)와의 상호작용 방식 등 기술적 작동 원리에 대한 구체적인 설명은 소스에 존재하지 않습니다.)*
|
||||
|
||||
## ⚖️ Trade-offs & Caveats
|
||||
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
|
||||
- **과거 데이터와의 충돌:** 자동화 엔진에 의해 매핑된 지식으로, 추후 정밀 검증 필요.
|
||||
- **정책 변화:** Programming & Language 분야의 자동 자산화 수행.
|
||||
|
||||
@@ -40,7 +53,7 @@ last_updated: 2026-05-02
|
||||
- AST 분석을 통해 실제 런타임 버그를 높은 비율로 발견할 수 있으나, 시스템의 기능성(functionality), 보안 취약점, 아키텍처 정렬 등을 완벽히 확인하기 위해서는 여전히 인간의 검증(Human validation)이 필수적으로 요구됩니다 [1].
|
||||
- *(소스에 관련 정보가 부족합니다: AST를 생성하거나 순회하는 과정에서 발생하는 컴퓨팅 리소스 소모, 메모리 오버헤드, 혹은 언어별 파싱 복잡도 등 직접적인 기술적 트레이드오프나 제약 사항에 대한 정보는 소스에 없습니다.)*
|
||||
|
||||
## 🔗 Knowledge Connections
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** CST(Concrete Syntax Tree), [[정적 애플리케이션 보안 테스트 (SAST)|정적 애플리케이션 보안 테스트(SAST]], 코드 스타일로메트리(Code Stylometry), [[정적 분석(Static Analysis)|정적 분석(Static Analysis]]
|
||||
- **Projects/Contexts:** 기계학습 기반의 소스 코드 저자 식별 연구, AI 기반 코드 복잡도 분석(카카오), 정적 보안 취약점 스캐닝 파이프라인
|
||||
- **Contradictions/Notes:** AST 기반의 분석은 작성자의 본질적인 프로그래밍 구조를 파악하고 위조 공격에 강하다는 장점이 있지만, 공백이나 들여쓰기 등 개발자의 개성이 묻어나는 '레이아웃 특징'을 담지 못합니다. 이로 인해 소스 코드 작성자 식별 실험에서 AST 기반 모델(51.00%)은 레이아웃 정보까지 포함하는 CST 기반 모델(67.86%)에 비해 상대적으로 낮은 정확도를 보였습니다 [10, 11].
|
||||
@@ -94,4 +107,41 @@ last_updated: 2026-05-02
|
||||
## 🧬 중복 검사 (Duplicate Check)
|
||||
- **기존 유사 문서:** None
|
||||
- **처리 방식:** CREATE
|
||||
- **처리 이유:** 신규 지식 체계 도입
|
||||
- **처리 이유:** 신규 지식 체계 도입
|
||||
|
||||
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
|
||||
|
||||
**언제 이 지식을 쓰는가:**
|
||||
- *(TODO)*
|
||||
|
||||
**언제 쓰면 안 되는가:**
|
||||
- *(TODO)*
|
||||
|
||||
## 🕓 변경 이력 (Changelog)
|
||||
|
||||
| 날짜 | 변경 내용 | 처리 방식 | 신뢰도 |
|
||||
|------|-----------|-----------|--------|
|
||||
| 2026-05-08 | P-Reinforce Phase 1 정규화 (frontmatter + 헤더 표준화) | UPDATE | A |
|
||||
|
||||
## 💻 코드 패턴 (Code Patterns)
|
||||
|
||||
**패턴 1:** *(TODO: 이 프로젝트 컨벤션 반영한 구조 스켈레톤)*
|
||||
|
||||
```text
|
||||
# TODO
|
||||
```
|
||||
|
||||
## 🤔 의사결정 기준 (Decision Criteria)
|
||||
|
||||
**선택 A를 써야 할 때:**
|
||||
- *(TODO)*
|
||||
|
||||
**선택 B를 써야 할 때:**
|
||||
- *(TODO)*
|
||||
|
||||
**기본값:**
|
||||
> *(TODO)*
|
||||
|
||||
## ❌ 안티패턴 (Anti-Patterns)
|
||||
|
||||
- **[안티패턴]:** *(TODO: 무엇을 하면 안 되는가 + 이유 + 대신 무엇을)*
|
||||
Reference in New Issue
Block a user