웹 프론트엔드 JS 튜토리얼 힙 및 가비지 수집 메커니즘에 대한 간략한 분석

힙 및 가비지 수집 메커니즘에 대한 간략한 분석

Jul 03, 2020 am 09:20 AM
쓰레기 수집 메커니즘

이 기사에서는 주로 다음 문제에 중점을 둡니다. Java 프로그램이 실행된 후 힙의 개체는 언제 재활용됩니까? 재활용하는 방법?

힙은 "GC 힙"이라고도 합니다. 이제 수집기는 기본적으로 세대별 수집 알고리즘을 사용하므로 Java 힙은 다음과 같이 세분화될 수도 있습니다. 비율은 1:2입니다. 신세대 세대는 에덴 영역과 서바이버 영역으로 나누어지며, 비율은 8:1이다. 다음 그림은 힙의 구조를 보여줍니다.

힙에 있는 객체의 메모리 할당은 엄격하게 규제됩니다. 전략은 다음과 같습니다.

  • 객체는 새로운 세대에서 메모리를 할당받습니다.

  • 대형 객체는 주로 긴 문자열과 배열로 직접 들어가며, 이는 많은 양의 연속 메모리 공간을 필요로 합니다.

  • 오랜 기간 동안 살아남은 객체 구세대. Eden 영역에 메모리가 충분하지 않으면 JVM은 MinorGC를 시작하고 객체의 수명은 1씩 증가합니다. 기본적으로 객체의 수명이 15에 도달하면 이전 수명이 됩니다. 나이결정. 동일한 age의 모든 객체 크기의 합이 Survivor 공간의 절반보다 크며, 이 age보다 크거나 같은 객체는 Old Generation에 들어갑니다. GC는 Minor GC를 의미하며 New Generation에서 자주 수행됩니다. 빠르게. Old Generation GC(Major GC/Full GC)는 일반적으로 하나 이상의 Minor GC와 함께 Old 세대에서 가비지 수집을 수행합니다. 느린. Full GC는 다음과 같은 상황에서 실행됩니다:

  • 메서드 영역의 공간이 부족함,

  • System.gc()를 호출하는 것이 좋습니다.

    장기 생존 개체가 이전 세대로 전송되고 공간이 부족합니다.
  1. 대형 개체에 할당할 연속 공간이 충분하지 않습니다.

  2. 신세대 가비지 컬렉션에는 살아남은 객체가 너무 많아 S1이 출시됩니다. 그렇지 않으면 Old 세대의 보장 공간이 부족한 것입니다. 보장 공간은 Old 세대에서 사용 가능한 최대 연속 공간이 그보다 큰지 여부를 나타냅니다. 새로운 세대의 모든 객체의 총 공간.
  3. 거의 모든 객체가 힙에 배치되는데, 이러한 객체가 여전히 유용한지 어떻게 알 수 있나요? JVM은 다음을 결정하는 두 가지 방법을 제공합니다.
  4. 참조 계산 방법

  5. : 참조될 때마다 참조 카운터가 1씩 증가합니다. , 카운터 값이 1씩 감소합니다. 참조 번호가 0이면 개체가 살아 있지 않음을 의미합니다. 참조 계산 방법으로는 순환 참조 문제를 해결할 수 없습니다. Zhou Zhipeng 선생님의 책에는 비교적 이해하기 쉬운 자세한 예가 있습니다.

접근성 분석 방법

: 트리의 루트 노드처럼 "GC Roots" 객체를 시작점으로 삼아 아래쪽으로 검색하고, It이라는 경로를 검색합니다. 참조 체인입니다. 객체에서 GC Roots의 시작점까지 참조 체인이 없으면 객체에 연결할 수 없으므로 재활용해야 합니다. GC 루트는 가상 머신 스택에서 참조하는 개체, 로컬 메서드 스택에서 참조하는 개체, 메서드 영역의 정적 속성에서 참조하는 개체, 메서드 영역의 상수에서 참조하는 개체를 참조합니다.
  • 위에서 언급했듯이 참조 유형은 참조 유형과 관련이 있습니다. . 가상 참조. 강력한 참조, 새 개체는 가비지 수집기에 의해 절대 재활용되지 않습니다.

소프트 참조, 이러한 개체의 메모리는 시스템이 OMM이 되기 전에 재활용됩니다. 약한 참조는 가비지 수집기가 작업 중에 발견하는 한 즉시 재활용됩니다. 가상 참조는 쓸모가 없으며 언제든지 재활용될 수 있습니다.

실제로 도달 가능성 분석에 의해 결정된 도달할 수 없는 객체는 즉시 재활용되지 않습니다. 객체는 실제로 재활용되기 전에 두 번 표시되어야 합니다. 첫 번째 마킹은 도달 불가능한 객체로 판단한 후 필터링을 수행하는 것입니다. 필터링 조건은 이 객체의 finalize() 메소드를 실행해야 하는지 여부입니다. finalize() 메서드가 재정의되지 않거나 가상 머신에서 finalize() 메서드를 호출한 경우 finalize() 메서드는 시스템에서 한 번만 호출됩니다. 두 경우 모두 "실행할 필요가 없습니다". 필요한 경우 이 개체는 F-Quene 대기열에 배치되고, 가상 머신에 의해 자동으로 생성된 우선 순위가 낮은 Finalizer 스레드가 finalize() 메서드를 실행합니다. 이 기간 동안 GC는 F-Quene의 개체에 대해 두 번째 소규모 표시를 수행합니다. 개체가 여전히 참조되지 않으면 필터링되지 않은 개체는 재활용되지 않을 수 있습니다. 재활용.

물체가 언제 재활용되는지는 이미 알고 있지만 어떻게 재활용할까요? 가장 일반적으로 사용되는 네 가지 가비지 수집 알고리즘 소개:

  • 표시 지우기: 먼저 지워야 할 개체를 표시한 다음 균일하게 재활용합니다. 이는 효율적이지 않으며 많은 수의 불연속 조각을 생성합니다.

  • 복사 알고리즘: 메모리를 블록으로 나누고 한 번에 하나의 블록만 사용합니다. 사용 후 살아남은 개체를 다른 블록에 복사합니다.

  • 표시 및 정렬: 살아남은 개체를 먼저 표시합니다. 그런 다음 살아남은 모든 개체를 한쪽 끝으로 이동하고 끝 경계 외부의 메모리를 직접 정리합니다.

  • 세대별 알고리즘으로 힙이 새 세대와 이전 세대로 나누어집니다. 새로운 세대가 수집될 때마다 복사 알고리즘을 선택하세요. 구세대의 생존율은 상대적으로 높고 할당 보장을 위한 추가 공간이 없으므로 마크 클리어 또는 마크 정렬 알고리즘을 선택하십시오.

가비지 수집 알고리즘은 메모리 재활용에 대한 아이디어이며 구체적인 구현은 가비지 수집기입니다. 일반적으로 사용되는 가비지 수집기에 대한 간략한 소개:

  • 직렬 직렬 수집기. 단일 스레드, 가비지 수집 중에는 다른 작업을 일시 중지해야 합니다. 신입생을 위한 복사, 노인을 위한 표시 및 분류. 간단하고 효율적입니다.

  • ParNew 수집가. 직렬의 다중 스레드 버전

  • 복사 알고리즘의 다중 스레드 수집기인 병렬 스캐빈지 수집기. 처리량, CPU 실행 코드 시간/사용된 총 CPU 시간에 주의하세요. 신입생 복사, 오래된 마크 정렬; . 동시 수집기를 사용하면 가비지 수집 스레드가 (기본적으로) 사용자 스레드와 동시에 작동합니다. Mark and Sweep Algorithm

  • 가비지 컬렉터에 대한 자세한 내용은 Mr. Zhou Zhipeng의 책을 읽어보세요.

  • 추천 튜토리얼: "
  • JS Tutorial

    "

위 내용은 힙 및 가비지 수집 메커니즘에 대한 간략한 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP의 가비지 수집 메커니즘에 대해 설명하는 기사 PHP의 가비지 수집 메커니즘에 대해 설명하는 기사 Aug 26, 2022 am 10:48 AM

이 기사는 PHP의 가비지 수집 메커니즘에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다.

Go 언어의 메모리 관리 및 가비지 수집 메커니즘 복호화 Go 언어의 메모리 관리 및 가비지 수집 메커니즘 복호화 Nov 30, 2023 am 09:17 AM

Go 언어는 효율적이고 안전하며 동시적인 프로그래밍 언어입니다. 메모리 관리 및 가비지 수집 메커니즘의 설계도 Go 언어의 고유한 특징입니다. 이 기사에서는 Go 언어의 메모리 관리 및 가비지 수집 메커니즘을 심층적으로 해독합니다. 1. 메모리 관리 Go 언어에서 메모리 관리에는 메모리 할당과 메모리 해제라는 두 가지 측면이 포함됩니다. 1.1 메모리 할당 Go 언어에서는 new 및 make 내장 함수를 통해 메모리를 할당합니다. 그 중 new는 새로 할당된 0 값에 대한 포인터를 반환하고, make는 지정된 유형과 길이를 반환합니다.

Java 함수에서 메모리 해제와 관련된 일반적인 문제를 해결하는 방법은 무엇입니까? Java 함수에서 메모리 해제와 관련된 일반적인 문제를 해결하는 방법은 무엇입니까? May 02, 2024 am 09:57 AM

Java의 메모리 관리에는 가비지 수집이 포함되지만 여전히 문제가 발생할 수 있습니다. 일반적인 문제에는 메모리 누수 및 메모리 조각화가 포함됩니다. 메모리 누수는 더 이상 필요하지 않은 참조를 보유하는 객체로 인해 발생하며 순환 참조를 피하고, 약한 참조를 사용하고, 변수 범위를 제한하여 해결할 수 있습니다. 메모리 조각화는 빈번한 할당 및 할당 해제로 인해 발생하며 메모리 풀, 대형 개체 풀 및 컴팩트 가비지 수집을 사용하여 해결할 수 있습니다. 예를 들어 약한 참조를 사용하면 메모리 누수를 처리하고 가비지 수집기가 더 이상 필요하지 않은 개체를 회수하도록 할 수 있습니다.

PHP의 기본 개발 원칙인 메모리 관리 및 가비지 수집 메커니즘에 대한 심층적인 이해 PHP의 기본 개발 원칙인 메모리 관리 및 가비지 수집 메커니즘에 대한 심층적인 이해 Sep 10, 2023 pm 02:30 PM

PHP의 기본 개발 원칙인 메모리 관리 및 가비지 수집 메커니즘에 대한 심층적인 이해 소개: 고급 프로그래밍 언어인 PHP는 웹 개발에 널리 사용됩니다. 많은 개발자가 PHP의 구문과 기능에 익숙하지만 PHP의 기본 개발 원칙에 대해서는 상대적으로 거의 이해하지 못할 수 있습니다. 이 기사에서는 독자가 PHP의 운영 메커니즘을 더 잘 이해할 수 있도록 PHP의 기본 개발 원칙에서 메모리 관리 및 가비지 수집 메커니즘을 자세히 살펴보겠습니다. 1. PHP의 메모리 관리 메모리 할당 및 해제 PHP의 메모리 관리는 Zend 엔진에 의해 처리됩니다.

Python의 가비지 수집 메커니즘에 대한 심층 분석 Python의 가비지 수집 메커니즘에 대한 심층 분석 Mar 29, 2018 pm 01:20 PM

Python의 자동 가비지 수집 메커니즘 덕분에 Python에서 객체를 생성할 때 수동으로 객체를 해제할 필요가 없습니다. 이는 매우 개발자 친화적이며 개발자가 낮은 수준의 메모리 관리에 대해 걱정할 필요가 없습니다. 그러나 가비지 수집 메커니즘을 이해하지 못한다면 작성하는 Python 코드는 종종 매우 비효율적일 것입니다.

JS의 가비지 수집 메커니즘에 대한 심층 분석 JS의 가비지 수집 메커니즘에 대한 심층 분석 Mar 02, 2023 pm 07:31 PM

기본 유형은 스택에 저장되고 참조 유형은 힙에 저장됩니다. JavaScript는 변수(객체, 문자열 등)가 생성될 때 자동으로 메모리를 할당하고, 사용되지 않을 때 "자동으로" 해제합니다. 릴리스 프로세스를 가비지 수집이라고 합니다.

Go 언어의 메모리 관리 기능과 가비지 수집 메커니즘 살펴보기 Go 언어의 메모리 관리 기능과 가비지 수집 메커니즘 살펴보기 Jan 23, 2024 am 10:07 AM

Go 언어의 가비지 수집 메커니즘과 메모리 관리 기능 살펴보기 소개: 인터넷이 발전함에 따라 개발자는 프로그래밍 언어에 대한 요구 사항이 점점 더 높아지고 있습니다. 정적으로 유형이 지정되고 컴파일되는 언어인 Go 언어는 효율적인 가비지 수집 메커니즘과 메모리 관리 기능으로 인해 처음부터 많은 주목을 받았습니다. 이 글의 목표는 Go 언어의 가비지 수집 메커니즘과 메모리 관리 기능을 심층적으로 살펴보고, 특정 코드 예제를 통해 독자가 이러한 기능을 더 잘 이해하고 활용할 수 있도록 돕는 것입니다. 1. 가비지 수집 메커니즘 1.1 Go 언어의 마크 스캔 알고리즘

탐색: JVM 가비지 수집 메커니즘의 다양한 개발 단계 탐색: JVM 가비지 수집 메커니즘의 다양한 개발 단계 Feb 23, 2024 pm 05:36 PM

심층 분석: JVM 가비지 수집 메커니즘의 다양한 진화에는 특정 코드 예제가 필요합니다. 1. 소개 컴퓨터 과학의 발전과 함께 가비지 수집 메커니즘은 JVM(Java Virtual Machine)에서 중요한 역할을 합니다. JVM 가비지 수집 메커니즘의 다양한 진화는 Java 프로그램의 성능과 메모리 관리를 향상시키는 것입니다. 이 기사에서는 JVM 가비지 수집 메커니즘의 구체적인 발전에 대한 심층 분석을 제공하고 독자의 이해를 돕기 위해 특정 코드 예제를 제공합니다. 2. JVM 가비지 컬렉션 메커니즘을 설명하는 데 있어서 가비지 컬렉션 메커니즘의 기본 원리

See all articles