ホームページ ウェブフロントエンド jsチュートリアル ヒープとガベージ コレクション メカニズムの簡単な分析

ヒープとガベージ コレクション メカニズムの簡単な分析

Jul 03, 2020 am 09:20 AM
ガベージコレクションの仕組み

この記事では主に次の問題に焦点を当てます:: Java プログラムの実行後、ヒープ内のオブジェクトはいつリサイクルされるか?リサイクルするにはどうすればいいですか?

ヒープは「GC ヒープ」とも呼ばれます。現在、コレクターは基本的に世代別コレクション アルゴリズムを使用しているため、Java ヒープは新世代と旧世代に細分することもできます。その割合は1:2、詳しく言うと新世代はエデンエリアとサバイバーエリアに分かれており、その割合は8:1となっています。次の図は、ヒープの構造を示しています。

##ヒープ内のオブジェクトに対するメモリの割り当ては厳密に行われます。

  • オブジェクトは最初に新世代の Eden 領域にメモリを割り当てます;

  • ## 大きなオブジェクトは、主に長い文字列や配列など、古い世代に直接入力され、大量の連続メモリ領域を必要とします。

  • 長期にわたって存続するオブジェクトは、古い世代に直接入力されます。古い世代。 Eden 領域のメモリが不十分な場合、JVM は MinorGC を開始し、オブジェクトの年齢が 1 つ増加します。デフォルトのオブジェクトの年齢は 15 に達し、古い年齢に入ります。

  • 動的な年齢決定。同じ年齢のすべてのオブジェクトのサイズの合計は、Survivor スペースの半分を超えています。この年齢以上のオブジェクトは古い世代に入ります

新世代の GC はマイナー GC を指し、新世代のガベージ コレクションは頻繁かつ高速です。古い世代の GC (メジャー GC/フル GC) は古い世代でガベージ コレクションを実行し、通常は少なくとも 1 つのマイナー GC を伴います。遅い。フル GC は次の状況でトリガーされます:

    古い世代のスペースが不十分;
  1. メソッド領域のスペースが不十分;
  2. #System.gc() を呼び出し、JVM が完全な gc を実行することをお勧めします;

  3. Long-存続期間中のオブジェクトは古い世代に転送されます。スペースが不足しています;

  4. #大きなオブジェクトに割り当てられる連続したスペースが十分にありません;
  5. # 新しい世代のガベージ コレクションで生き残るオブジェクトが多すぎるため、S1 がそれ​​らを収容できません。古い世代の保証された領域が不足しています。保証された領域とは、利用可能な最大のスペースがあるかどうかを指します。古い世代の連続スペースは、新しい世代のすべてのオブジェクトの合計スペースよりも大きくなります。
  6. ほとんどすべてのオブジェクトはヒープに配置されます。では、これらのオブジェクトがまだ使用できるかどうかをどのように確認すればよいでしょうか? JVM は、次の 2 つの決定方法を提供します。

  • ##参照カウント方法

    : オブジェクトは、参照カウンタ。参照されるたびにカウンタ値が 1 増加し、参照が無効になるとカウンタ値が 1 減少します。参照回数が 0 の場合、オブジェクトは生きていないことを意味します。参照カウント法では循環参照問題は解決できませんが、周志鵬先生の本に詳細な例が載っており、比較的理解しやすいです。

  • #到達性分析手法 :ツリーのルートノードと同様に、「GC Roots」オブジェクトを起点として下方向に探索します。その探索でたどる経路を参照チェーンと呼びます。オブジェクトから開始点までの参照チェーンが存在しない場合は、 GC ルート、次にこれ オブジェクトは到達できないため、リサイクルする必要があります。 GC ルートは、仮想マシン スタックによって参照されるオブジェクト、ローカル メソッド スタックによって参照されるオブジェクト、メソッド領域の静的プロパティによって参照されるオブジェクト、およびメソッド領域の定数によって参照されるオブジェクトを指します。

参照については上で説明しました。オブジェクトの存続は参照に関係します。参照の種類は、強参照、ソフト参照、弱参照、仮想参照に分類されます。

強力な参照、新しいオブジェクト、ガベージ コレクターはそれをリサイクルしません;

  • ソフト参照。システム内で OMM が発生する前に、これらのオブジェクトのメモリがリサイクルされます。

  • 弱い参照。ガベージ コレクターがそれを見つけるとすぐに再利用されます。動作している場合、すぐにリサイクルされます ;

  • 仮想参照は役に立たず、いつでもリサイクルされる可能性があります。

実際には、到達可能性分析メソッドによって決定された到達不可能なオブジェクトはすぐにはリサイクルされません。オブジェクトはその前に 2 回マークされる必要があります。実際にはリサイクルされます。最初のマーキングでは、オブジェクトが到達不能であると判断され、次にフィルターが実行されます。フィルター条件は、このオブジェクト # の Finalize() メソッド # を実行する必要があるかどうかです。 ####。 Finalize() メソッドがオーバーライドされていない場合、または Finalize() メソッドが仮想マシンによって呼び出された場合、finalize() メソッドはシステムによって 1 回だけ呼び出されます。どちらの場合も「実行する必要はありません」。必要に応じて、このオブジェクトは、仮想マシンによって自動的に作成される低優先度 キューである F-Quene キューに配置されます。 Finalizerスレッドは、finalize() メソッドを実行します。この期間中、GC は 2 番目の小規模なスケールで F-Quene 内のオブジェクトをマークします。オブジェクトがまだ参照されていない場合は、リサイクルされます。フィルタリングされないオブジェクトは必ずしもリサイクルされるわけではありません。 #オブジェクトが何であるかはすでにわかっています時間はリサイクルされていますが、どのようにリサイクルすればよいでしょうか?最も一般的に使用される 4 つのガベージ コレクション アルゴリズムを紹介します。

マーククリア: 最初にクリアする必要があるオブジェクトにマークを付け、次にそれらを均一に収集します --- - 効率的ではありません、大量の不連続フラグメントが生成されます;

  • コピー アルゴリズム: メモリをブロックに分割し、一度に 1 つのブロックのみを使用してコピーします使用後に残ったオブジェクトを別のオブジェクトに移動します。1 つのピースで;

  • マーク付けと並べ替え: 最初に残ったオブジェクトにマークを付け、次に残ったすべてのオブジェクトを一方の端に移動します。終了境界の外側のメモリを直接クリーンアップします;

  • 世代アルゴリズムでは、ヒープは新しい世代と古い世代に分割されます。新しい世代が収集されるたびに消滅するため、コピー アルゴリズムを選択します。旧世代の生存率は比較的高く、割り当て保証のための余分なスペースがないため、マーク クリアまたはマーク ソート アルゴリズムを選択します。

  • ガベージ コレクション アルゴリズムはメモリのリサイクルのアイデアであり、具体的な実装はガベージ コレクターです。一般的に使用されるガベージ コレクターの簡単な紹介:

シリアル シリアル コレクター。単一スレッドの場合、ガベージ コレクション中は他の作業を一時停止する必要があります。新入生にはコピー、老人にはラベリング。シンプルで効率的;

  • ParNew コレクター。シリアルのマルチスレッド バージョン、

  • Parallel Scavenge コレクター、レプリケーション アルゴリズムのマルチスレッド コレクター。スループット、CPU 実行コード時間 / 合計 CPU 消費時間に注意してください。新世代のコピー、旧マークのソート;

  • シリアル古いコレクター、旧世代のバージョン;

  • Parallel Old コレクター、Parallel Scavenge 旧世代バージョン;

  • CMS コレクター、最短の一時停止に焦点を当てています。並行コレクタを使用すると、ガベージ コレクション スレッドは (基本的に) ユーザー スレッドと同時に動作します。マーク アンド スイープ アルゴリズム

  • ガベージ コレクターの詳細については、Zhou Zhipeng 氏の本をご覧ください。

  • 推奨チュートリアル: 「
JS チュートリアル

以上がヒープとガベージ コレクション メカニズムの簡単な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

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 言語のメモリ管理とガベージ コレクションのメカニズムを詳しく解読します。 1. メモリ管理 Go 言語では、メモリ管理にはメモリ割り当てとメモリ解放という 2 つの側面が含まれます。 1.1 メモリ割り当て Go 言語では、組み込み関数 new および make を通じてメモリを割り当てます。このうち、new は新しく割り当てられたゼロ値へのポインタを返し、make は指定された型とその長さを返します。

Java 関数でのメモリ解放に関する一般的な問題を解決するにはどうすればよいですか? Java 関数でのメモリ解放に関する一般的な問題を解決するにはどうすればよいですか? May 02, 2024 am 09:57 AM

Java のメモリ管理にはガベージ コレクションが含まれますが、それでも問題が発生する可能性があります。一般的な問題には、メモリ リークやメモリの断片化などがあります。メモリ リークは、オブジェクトが不要になった参照を保持することによって発生します。これは、循環参照を回避し、弱い参照を使用し、変数のスコープを制限することで解決できます。メモリの断片化は、頻繁な割り当てと割り当て解除によって発生し、メモリ プール、ラージ オブジェクト プール、およびコンパクト ガベージ コレクションを使用することで解決できます。たとえば、弱い参照を使用すると、メモリ リークを処理し、オブジェクトが不要になったときにガベージ コレクターが確実にオブジェクトを再利用できるようになります。

PHP の基礎となる開発原則 (メモリ管理とガベージ コレクション メカニズム) についての深い理解 PHP の基礎となる開発原則 (メモリ管理とガベージ コレクション メカニズム) についての深い理解 Sep 10, 2023 pm 02:30 PM

PHP の基礎となる開発原則 (メモリ管理とガベージ コレクション メカニズム) についての深い理解 はじめに: PHP は、高水準プログラミング言語として、Web 開発で広く使用されています。多くの開発者は PHP の構文と機能には精通していますが、PHP の基礎となる開発原則についてはほとんど理解していない可能性があります。この記事では、読者が PHP の動作メカニズムをより深く理解できるように、PHP の基礎となる開発原則におけるメモリ管理とガベージ コレクションのメカニズムを深く掘り下げていきます。 1. PHP のメモリ管理 メモリの割り当てと解放 PHP のメモリ管理は Zend エンジンによって処理されます

JS のガベージ コレクション メカニズムの詳細な分析 JS のガベージ コレクション メカニズムの詳細な分析 Mar 02, 2023 pm 07:31 PM

プリミティブ型はスタックに格納され、参照型はヒープに格納されます。 JavaScript は、変数 (オブジェクト、文字列など) が作成されるときに自動的にメモリを割り当て、使用されないときにそれらを「自動的に」解放します。解放するプロセスはガベージ コレクションと呼ばれます。

Python のガベージ コレクション メカニズムの詳細な分析 Python のガベージ コレクション メカニズムの詳細な分析 Mar 29, 2018 pm 01:20 PM

Python の自動ガベージ コレクション メカニズムのおかげで、Python でオブジェクトを作成するときにオブジェクトを手動で解放する必要はありません。これは開発者にとって非常に使いやすく、開発者は低レベルのメモリ管理について心配する必要がなくなります。しかし、ガベージ コレクションのメカニズムを理解していないと、作成する Python コードは非常に非効率なものになることがよくあります。

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