>  기사  >  Java  >  JVM 메모리 관리------가비지 수집기 소개

JVM 메모리 관리------가비지 수집기 소개

黄舟
黄舟원래의
2016-12-28 15:50:231343검색

이전 장에서 다양한 GC 알고리즘에 대해 설명했는데 가비지 컬렉터란 무엇인가요?
일반인의 관점에서 볼 때, 프로그래밍 언어를 사용하여 알고리즘을 구현하면 결과 프로그램은 가비지 수집기입니다. 이제 프로그래밍 언어 구현에 대해 이야기했으므로 가비지 수집기에 대해 논의할 때 이미 특정 가상 머신 구현을 포함했습니다.
아마도 많은 JAVA 개발자들은 우리가 일반적으로 사용하는 JDK에서 기본 JVM이 핫스팟이라는 사실을 모르고 있습니다. 즉, 우리가 가장 많이 사용하는 JVM은 핫스팟의 구현 버전이라는 것입니다. 이번 LZ에서는 모두 JVM의 핫스팟 버전을 기반으로 합니다.
좀 더 직관적으로, 우리가 일반적으로 개발하는 머신의 JVM 버전을 확인하기 위해 java -version을 입력할 수 있습니다. LZ 머신의 스크린샷은 다음과 같습니다.

JVM 메모리 관리------가비지 수집기 소개

가비지 컬렉터 분류

위에서 가비지 컬렉터는 실제로 알고리즘을 프로그래밍 언어로 구현한 것이라고 언급했습니다. 프로그래밍 언어가 관련되어 있기 때문에 스레드는 분리될 수 없어야 하며 앞서 알고리즘을 설명할 때 우리는 항상 GC 스레드가 GC 작업을 하고 있다고 가정했습니다.
따라서 가비지 컬렉터는 크게 다음 세 가지로 분류됩니다.
직렬 수집기: GC 스레드가 하나만 있고 앞서 언급했듯이 실행 시 사용자 프로그램을 일시 중지(세계를 중지)해야 합니다.
병렬 수집기: 여러 개의 GC 스레드가 있으며 사용자 프로그램을 일시 중지해야 합니다(세상을 중지).
동시 컬렉터: 하나 이상의 GC 스레드를 가지고 있으며 일부 단계에서 사용자 프로그램을 일시 중지(세계 중지)하고 사용자 프로그램과 동시에 단계의 일부를 실행해야 합니다.

동시 및 병렬

위의 정의를 읽은 후 일부 유인원 친구들은 때로는 단일 스레드, 때로는 다중 스레드, 때로는 직렬, 때로는 혼란스러워했다고 생각합니다. 가끔 동시다발적으로, 이게 다 말도 안되는 소리인가요?
단일 스레드와 다중 스레드에 대해서는 더 이상 말할 필요가 없습니다. 직렬과 병렬도 이해하기 쉽습니다. 병렬과 동시입니다.
동시성에 대한 많은 설명 중 LZ는 가장 적절한 설명이 있다고 생각합니다. 이렇게 설명하면 동시성이란 두 작업 A와 B가 서로 독립적으로 실행되어야 하며 작업 A가 먼저 시작된 후 작업 A가 끝나기 전에 작업 B가 시작된다는 의미입니다.
동시성 자체는 비교적 이해하기 쉬운데, 병렬성과의 관계와 차이점은 무엇인가요?
실제로 병렬성은 동시성을 구현하는 방법입니다. LZ는 이렇게 말하면 더 잘 이해할 수 있다고 생각합니다. 물론 병렬 처리가 동시성을 달성하는 유일한 방법은 아닙니다. 우리에게 익숙한 시간 분할 전환입니다. 즉, 태스크 A는 잠시 실행되고, 태스크 B는 잠시 실행되고, 교대로 실행됩니다.
병렬화는 멀티 코어 멀티 프로세서 또는 분산 시스템(기본적으로 여전히 멀티 코어 멀티 프로세서)의 전제에서만 발생할 수 있는 반면, 대체 실행 또는 타임 슬라이스 전환은 단일 코어 프로세서에서 발생합니다.

핫스팟의 가비지 컬렉터

위에서 가비지 컬렉터의 분류에 대해 간략하게 설명했습니다. HotspotJVM에서는 각 가비지 컬렉터 유형에 대해 다음과 같이 해당 구현이 있습니다.
직렬 수집기 구현: serial(신세대에서 사용, 복사 알고리즘 사용), 직렬 old(구세대에서 사용, 표시/조합 알고리즘 사용)
병렬 수집기 구현: ParNew(신세대에서 사용, 사용) 복사 알고리즘), Parallel Scavenge(신세대에서 사용, 복사 알고리즘 사용), Parallel old(구세대에서 사용, 마킹/콜레이션 알고리즘 사용)
동시 수집기 구현: 동시 마크 스윕 [CMS ] (구세대에서는 마크/클리어 알고리즘을 사용)
보시다시피, 위의 가비지 컬렉터들은 각각 서로 다른 알고리즘을 사용하기 때문에 서로 다른 메모리 영역에 맞게 설계되었습니다. Old 세대에 사용되는 것들은 모두 복사 알고리즘을 사용하고, Old 세대에 사용되는 것들은 mark/clear 또는 mark/complement 알고리즘을 사용합니다.
실제 적용에서는 JVM의 신세대와 구세대에 대한 가비지 수집기를 선택해야 합니다. 즉, 신세대와 구세대 모두에 대해 세 가지 구현이 있음을 알 수 있습니다. 3 *3=9 선택. 그러나 이는 사실이 아니다.

사실 이 6개의 가비지 컬렉터에 대한 선택지는 6개뿐인데, 일부 가비지 컬렉터는 아래 그림과 같이 특정 구현 방법 등 일련의 이유로 함께 작동할 수 없기 때문입니다.

JVM 메모리 관리------가비지 수집기 소개

위 그림에서 빨간색이 직렬 컬렉터, 녹색이 병렬 컬렉터, 노란색만 유일하게 동시 컬렉터입니다. 상위 3개는 신세대 수집가이고, 하위 3개는 구세대 수집가입니다. 둘 사이에 연결이 있다면 둘이 함께 일할 수 있다는 뜻이다.
이 여섯 가지 조합은 어떤 조합이 가장 강하고 어떤 조합이 가장 약한지를 말하지 않습니다. 다시 말하지만, 가장 적합한 조합만 있고 최고는 없습니다. 따라서 이를 사용할 때 보다 적합한 가비지 수집기를 선택하려면 각 조합에 대해 어느 정도 이해해야 합니다.

결론

위 내용은 JVM 메모리 관리------가비지 컬렉터 소개 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.