GC 알고리즘
Java에서 Mark and Sweep 말고도 다른 알고리즘을 조합해서 사용한다고 하는데요.
이렇게 Mark and Sweep만 키워드로 가져가도 괜찮을까요??
回答 2
1
안녕하세요, Cola님!
Mark and Sweep을 핵심 키워드로 가져가시는 건 충분히 괜찮습니다. Mark는 모든 GC 알고리즘의 공통 출발점이라, 어느 컬렉터를 쓰더라도 "GC Root에서 시작해 reachable 객체를 마킹한다"는 점은 동일하기 때문이에요.
다만 면접 답변을 더 풍성하게 가져가시려면, Mark and Sweep 외에 함께 알아두시면 좋은 알고리즘 두 가지가 있습니다.
Mark and Compact: 마킹 후 살아남은 객체를 한쪽으로 모아 정리 → Mark and Sweep의 단편화 문제를 해결, Old Generation에서 사용
Copying: 살아남은 객체를 다른 영역으로 복사 → Young Generation의 Eden ↔ Survivor 사이 이동에 사용
전체 구조로 정리하면 이렇습니다.
[GC의 큰 틀]
└ Mark and Sweep (마킹 → 정리)
[영역별 정리 방식]
├ Young Generation : Copying
└ Old Generation : Mark and Sweep / Mark and Compact
면접에서 "GC 동작 원리"가 메인 질문으로 나오면 Mark and Sweep을 출발점으로 답변하시고, 후속 질문이 들어올 때 위 두 알고리즘으로 확장하시면 됩니다!
0
안녕하세요, 인프런 AI 인턴입니다. Cola님!
Java의 가비지 컬렉션(GC)은 Mark and Sweep 외에도 여러 가지 알고리즘을 조합해서 사용합니다. Mark and Sweep은 가장 기본적인 GC 방식 중 하나로, 객체를 마크하고 쓸모없는 객체를 수거하는 방식입니다.
하지만 현대적인 JVM에서는 다양한 GC 알고리즘이 존재합니다. 예를 들어, 젠코브리터나 CMS(Concurrent Mark-Sweep), G1(Garbage-First) 등이 있으며, 각 알고리즘은 성능 최적화와 목적에 따라 요소를 다르게 조합해서 사용합니다. 그러므로 면접이나 테스트에서 “Mark and Sweep”만을 언급하기보다는, 여러 GC 알고리즘을 이해하고 그 특징과 사용 사례를 알고 있는 것이 더욱 유리할 수 있습니다.
관련하여 실행과정 질문입니다. 질문을 참고하시면, Java의 실행 및 컴파일 과정을 이해하는 데 도움이 될 것입니다. 이를 통해 Java 내부에서 어떻게 가비지 컬렉션이 수행되는지 더 잘 이해할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
강의노트 접속 불가
0
5
1
Kafka Cluster 구성도 질문
0
6
1
SingletonService가 JVM이 뜰 때 생성되는게 맞나요?
0
6
1
26년 1회차 기출 강의
0
28
2
기출문제
0
48
1
정보처리기사 실기 zip
0
38
2
답을언제쯤받아볼수있나요
0
46
2
데이터베이스 노션
0
36
2
형 책 어떻게 받아?
1
50
1
PPT 자료 공유 받을 수 있을까요?
0
29
1
본 강의와는 상관없는 내용입니다만..
0
35
1
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
28
2
수업노선자료파일 다운
0
34
2
5~9까지 램덤숫자출력
0
27
1
프로젝트가 없어요..
0
55
2
C언어에서
0
50
1
질문있습니다.
1
61
2
멀티스레드
1
58
2
성능 오버헤드
1
53
2
volatile에 대해 질문 있습니다.
2
85
2
Mark and Sweep
1
58
1
용어 질문
1
39
1
호출횟수 질문입니다.
1
55
2
실행과정 질문입니다.
2
56
1

