Garbage Collection - Garabge, Garbage collection, 정의, 알고리즘
Garbage Collection
Garbage
Definition
- 특정 메모리 영역을 사용하고 이후에 사용하지 않는데도 지속적으로 해당 영역에 남아 있어 메모리 낭비
Effect
1. Dangling Pointer
- 메모리를 사용 후 직접적으로 free를 해주어야 하기 때문에 garbage collection을 사용하지 않으면 사용되지 않는 메모리 영역이 생길 수 있음
2. Double Free
- 메모리를 사용 후 직접적으로 free 해주어야 하기 때문에 garbage collection을 이용하지 않으면 한 영역을 두번 free하는 경우가 생길 수 있음
3. Memory Leak
- 사용되지 않는 메모리때문에 메모리 누수가 일어날 수 있음
Garbage Collection
Definition
- Garbage들을 회수하여 메모리 낭비를 없앰
Language
1. C/C++
- Garbage Collection이 언어 자체에 포함되어 있지 않아 직접 구현해야함
- 사용자가 직접 메모리를 할당하고 해제할 수 있어, 메모리 사용 후 직접 free해주지 않으면 garbage 발생
- Library를 사용하여 Garbage Collection 사용 가능
2. Java, C#, Python
- Garbage Collection이 구현되어 있음
- 동적으로 할당한 메모리 영역을 완벽하게 관리할 필요가 없음
구현 기법(알고리즘)
1. Mark and Sweep
- 할당된 메모리 영역 중 1비트를 mark bit로 사용
- 일정 시간에 garbage collection이 수행되며 접근 가능한 메모리의 mark bit를 확인하여 mark bit가 활성화되지 않은 영역은 swepp(해제)
- garbage collection이 수행되는 도중 메모리가 변경되면 마킹을 다시해야하기 때문에 garbage collection 수행 시 정지(stop-the-world)
ref) stop-the-world : garbage collection을 수행하기 위해 Application을 중지
2. Copying GC
- 동적 메모리가 할당되는 heap 영역을 active와 inactive 영역으로 나누고 active 영역에만 메모리 할당이 이루어지도록 함
- active 영역이 full이 되면 garbage collection을 수행
3. Generational GC
- 동적 메모리가 할당되는 heap 영역을 young, old와 같은 generation으로 나누고 각 generation은 sub heap을 가지고 있는 형태
- 각 generation별로 효율적인 알고리즘 적용 가능