[G1-Sync] Manual knowledge update
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
---
|
||||
id: P-REINFORCE-AUTO-438240
|
||||
id: [[P-Reinforce]]-AUTO-438240
|
||||
category: "10_Wiki/💡 Topics/Programming & Language"
|
||||
confidence_score: 0.90
|
||||
tags: [auto-reinforced]
|
||||
@@ -10,7 +10,7 @@ github_commit: "[P-Reinforce] Continuous Worker - V8 힙 공간(V8 Heap Spaces)"
|
||||
# [[V8 힙 공간(V8 Heap Spaces)]]
|
||||
|
||||
## 📌 한 줄 통찰 (The Karpathy Summary)
|
||||
> V8 엔진은 동적으로 할당되는 데이터와 객체를 저장하기 위해 힙(Heap) 메모리를 사용하며, 효율적인 메모리 관리를 위해 이를 여러 개의 특화된 공간(Space)으로 나눕니다 [1, 2]. 객체의 예상 수명과 크기, 내부 포인터의 유무에 따라 신규 공간(New Space), 올드 공간(Old Space), 대형 객체 공간(Large Object Space) 등으로 분리됩니다 [2-4]. 이러한 공간 분할은 가비지 컬렉터(GC)가 각 메모리 영역의 특성에 맞는 최적화된 수집 알고리즘을 적용할 수 있게 하여 애플리케이션의 성능을 향상시킵니다 [2]. 또한 최신 V8에서는 보안과 성능을 위해 포인터 압축 기술을 사용하여 전체 힙 공간을 4GB 크기의 메모리 케이지(Memory Cage) 내에 제한합니다 [5, 6].
|
||||
> V8 엔진은 동적으로 할당되는 데이터와 객체를 저장하기 위해 힙(Heap) 메모리를 사용하며, 효율적인 메모리 관리를 위해 이를 여러 개의 특화된 공간(Space)으로 나눕니다 [1, 2]. 객체의 예상 수명과 크기, 내부 포인터의 유무에 따라 신규 공간(New Space), 올드 공간([[Old Space]]), 대형 객체 공간(Large Object Space) 등으로 분리됩니다 [2-4]. 이러한 공간 분할은 가비지 컬렉터(GC)가 각 메모리 영역의 특성에 맞는 최적화된 수집 알고리즘을 적용할 수 있게 하여 애플리케이션의 성능을 향상시킵니다 [2]. 또한 최신 V8에서는 보안과 성능을 위해 포인터 압축 기술을 사용하여 전체 힙 공간을 4GB 크기의 메모리 케이지([[memory]] Cage) 내에 제한합니다 [5, 6].
|
||||
|
||||
## 📖 구조화된 지식 (Synthesized Content)
|
||||
V8 힙은 각기 다른 생명주기를 가진 객체를 관리하기 위해 여러 하위 공간으로 논리적으로 분할되며, 각 공간은 운영체제로부터 할당받은 '페이지(Page)'라는 연속된 메모리 청크의 집합으로 구성됩니다 [7-9]. V8 힙 공간의 주요 구성 요소는 다음과 같습니다:
|
||||
@@ -19,11 +19,11 @@ V8 힙은 각기 다른 생명주기를 가진 객체를 관리하기 위해 여
|
||||
* 대부분의 새로운 객체가 최초로 할당되는 곳입니다 [2-4].
|
||||
* 수명이 짧은 객체를 신속하게 수집하기 위해 설계되었으며, 크기가 작습니다(휴리스틱에 따라 일반적으로 1~8MB 또는 최대 64MB) [4, 10-12].
|
||||
* 할당 및 가비지 컬렉션을 위해 내부적으로 크기가 동일한 `to-space`와 `from-space`라는 두 개의 반공간(semi-space)으로 나뉩니다 [4, 11, 13, 14].
|
||||
* 이 공간은 스캐빈저(Scavenger)를 통한 마이너 가비지 컬렉션(Minor GC)에 의해 독립적으로 매우 빠르게 관리됩니다 [2-4, 10].
|
||||
* 이 공간은 스캐빈저([[Scavenge]]r)를 통한 마이너 가비지 컬렉션(Minor GC)에 의해 독립적으로 매우 빠르게 관리됩니다 [2-4, 10].
|
||||
|
||||
* **올드 공간 (Old Space / Old Generation)**
|
||||
* 신규 공간에서 두 번의 마이너 GC를 거치고 생존한 장기 생존 객체들이 승격(Promote)되어 이동하는 공간입니다 [4, 10, 15].
|
||||
* 메이저 가비지 컬렉션(Mark-Sweep-Compact) 알고리즘의 대상이 되며, 효율적인 관리를 위해 다시 두 가지로 세분화됩니다 [4, 10, 16].
|
||||
* 메이저 가비지 컬렉션([[Mark-Sweep]]-Compact) 알고리즘의 대상이 되며, 효율적인 관리를 위해 다시 두 가지로 세분화됩니다 [4, 10, 16].
|
||||
1. **올드 포인터 공간 (Old Pointer Space):** 다른 객체를 가리키는 내부 포인터를 포함하는 객체들이 저장됩니다 [2-4].
|
||||
2. **올드 데이터 공간 (Old Data Space):** 문자열, 박싱된 숫자(boxed numbers), 포인터가 없는 배열 등 원시 데이터만 포함하는 객체들이 저장됩니다 [2-4]. GC가 이 공간을 처리할 때는 포인터 추적(tracing) 단계를 건너뛸 수 있어 작업 속도를 최적화할 수 있습니다 [2, 17].
|
||||
|
||||
@@ -44,7 +44,7 @@ V8 힙은 각기 다른 생명주기를 가진 객체를 관리하기 위해 여
|
||||
- **정책 변화:** Programming & Language 분야의 자동 자산화 수행.
|
||||
|
||||
## 🔗 지식 연결 (Graph)
|
||||
- **Related Topics:** 가비지 컬렉션(Garbage Collection), 스캐빈저(Scavenger), 마크-스위프-컴팩트(Mark-Sweep-Compact)
|
||||
- **Related Topics:** 가비지 컬렉션([[Garbage Collection]]), 스캐빈저(Scavenger), 마크-스위프-컴팩트(Mark-Sweep-Compact)
|
||||
- **Projects/Contexts:** [[Orinoco 프로젝트]], [[V8 메모리 케이지(V8 Memory Cage)]]
|
||||
- **Contradictions/Notes:** 전통적으로 V8 힙을 구성하는 단위인 각 '페이지(Page)'의 크기는 1MB였으나, 최근 저사양 모바일 기기를 위한 메모리 절감 및 파편화 감소 최적화의 일환으로 512KB 크기의 페이지로 축소 변경되기도 하였습니다 [7, 8, 19, 20].
|
||||
|
||||
|
||||
Reference in New Issue
Block a user