힙 ( Heap )

2025. 10. 10. 12:36·⭐C Sharp/메모리 관리

메모리 구조 힙 ( Heap )

힙 ( Heap ) 영역은 프로그램이 실행되는 동안 동적으로 생성되는 데이터 ( 객체 , 배열 등 ) 를 저장하는 메모리 공간이다.

이 영역은 컴파일 시점 ( Compile )이 아니라, 실행 시점 ( Runtime )에 메모리 크기와 생명주기가 결정된다는 점이 핵심이다.

다시 말해, 스택 ( Stack )과는 달리 메모리 크기가 정해져 있지 않고 프로그램이 실행되는 도중에 크기나 개수가 가변적인 데이터를 저장하기 위한 공용 저장소 역할을 하는 공간이다.

C언어 같은 예전 언어들은 사용 후 반드시 개발자가 직접 해제해야 한다.

 


 

작동 원리

프로그램이 실행되면 운영체제 ( OS ) 는 프로세스에 여러 영역을 나누어 메모리를 할당해준다.

대표적으로 Code , Data , Stack , Heap 네 가지 영역으로 나눈다.

 

그중 Heap 은 프로그램의 메모리 공간 중 가장 유연하게 확장 가능한 부분으로,

필요에 따라 운영체제가 메모리를 동적으로 확보하거나 해제할 수 있다.

  • 개발자가 new , malloc ( ) 등을 호출하면 OS 는 Heap 영역에서 일정 크기의 공간을 찾아서 할당해준다.
  • 이렇게 할당된 메모리의 주소값 ( 참조 )이 반환되어 Stack 영역의 변수 ( 참조형 변수) 가 이를 가리키게 된다.
  • 이후 해당 객체를 더 이상 참조하지 않으면 , C# 에서는 GC 가 주기적으로 이 Heap 을 탐색하여 불필요한 객체를 정리해준다.
    └ 이 과정에서 Stack 에서는 일어나지 않는다. Stack 은 함수 종료 시 자동 정리된다.

 

구분 설명
위치 프로세스 메모리 구조의 상단 쪽에 위치 ( Stack 영역의 반대 방향으로 성장 )
할당 시점 프로그램 실행 중 ( new , malloc ( ) 등으로 동적 할당할 때 )
해제 시점 명시적 해제 ( delete , free ( ) ) 또는 가비지 컬렉터 ( GC ) 가 자동으로 해제 
수명 명시적으로 해제될 때까지 유지된다. 함수가 끝나도 남아있다.
속도 Stack 보다 느리다. ( 할당 / 해제 관리가 복잡하다 )
관리 주체 프로그래머 또는 GC
용도 객체 , 배열 , 컬렉션 ( List , Dictionary 등 ) 같은 참조형 데이터 저장

예시 코드

class Player
{
    public int hp;
    public string name;
}

void Main()
{
    // new 로 생성된 객체는 Heap 에 저장됨
    Player hero = new Player();
    hero.hp = 100;
    hero.name = "HoChan";
}
  • hero 변수 자체는 Stack 영역에 저장한다.
  • new Player( ) 로 만들어진 Player 객체의 데이터 ( hp , name ) 는 Heap 영역에 저장된다.
  • Stack 의 hero 변수는 Heap 에 있는 객체를 참조 ( Reference ) 하는 역할을 한다.

이때 , 함수 Main( ) 이 끝나면 hero 변수는 Stack 에서 사라지지만,

Heap 에 있던 Player 객체는 GC 가 회수하기 전까지는 메모리에 남아있는다.

 


 

Heap 메모리 관리 흐름

  1. new 연산자 → Heap 에 메모리 공간 확보
  2. 변수 ( 참조형 ) 가 해당 객체의 주소를 Stack 에 저장한다
  3. 더 이상 참조되지 않으면 Garbage Collector 가 탐지한다
  4. GC 가 필요 시 Heap 에서 해당 객체를 정리 ( 해제 ) 한다

주의할 점

  1. Heap 메모리 누수 ( Leak )
    └ GC가 없는 언어 ( C / C++ ) 에서는 free( ) 를 빼먹으면 메모리가 계속 남는다.
    └ C# 에서도 GC 가 즉시 회수하지 않기 때문에, 짧은 시간에 많은 객체를 반복 생성하면 성능 저하가 있다.
  2. 할당 비용이 크다
    └ Stack 은 단순히 포인터만 움직이지만 , Heap은 OS 레벨의 메모리 요청이 필요하므로 상대적으로 느리다.
    └ 따라서 짧게 쓰이는 임시 변수는 Heap 보다 Stack 에 두는 것이 훨씬 효율적이다
  3. 조심해야 할 참조 유지 ( Reference Hold )
    └ 이미 필요 없는 객체를 여전히 참조 중이라면 , GC 는 그 객체를 살아있다고 판단해 회수하지 않는다.
    └ null 처리나 스코프 제한으로 의도적으로 참조를 끊어주는 습관이 좋다.

정리

Heap 은 프로그램 실행 중에 동적으로 생성되는 객체나 데이터가 저장되는 공간이다.

참조형 변수들이 실제로 가리키는 메모리 영역이다.

Stack 보다 오래 유지되며 GC가 자동으로 관리하는 동적 메모리 공간이다.

'⭐C Sharp > 메모리 관리' 카테고리의 다른 글

스택 ( Stack )  (0) 2025.10.10
가비지 컬렉터 ( GC )  (0) 2025.10.10
'⭐C Sharp/메모리 관리' 카테고리의 다른 글
  • 스택 ( Stack )
  • 가비지 컬렉터 ( GC )
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    CodingTest
    유니티
    기획
    게임디자인
    객체지향
    c#
    gamedesign
    til
    csharp
    문법
    unity
    algorithm
    자료형
    디자인패턴
    부트캠프
    OOP
    메모리관리
    게임기획
    GitHub
    자료구조
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
힙 ( Heap )
상단으로

티스토리툴바