Java でのリサイクルされたオブジェクトのマーキングとオブジェクトの二次マーキング プロセスの詳細な説明
この記事は主に Java リサイクル オブジェクトのマーキングとオブジェクトの二次マーキング プロセスについて紹介しています。必要な方はここで共有します。
1. オブジェクトのマーキング
1. マークとは何ですか?マークの付け方は?
最初の質問は、ガベージ コレクターの掃除を容易にするために、いくつかの死んだオブジェクトにマークを付けることであることは誰もが知っていると思います。 マークの付け方としては、大きく分けて参照カウントと到達可能性解析の2つの方法があります。
参照カウントの実装は比較的簡単です。オブジェクトへの参照があるたびに、参照カウンターが 1 ずつ増加します。参照が無効な場合は、1 ずつ減少します。カウンタが 0 になると、リサイクル可能としてマークされます。この判断は非常に効率的ですが、多くの主流の仮想マシンはこの方法を使用していません。主な理由は、複数のオブジェクト間の循環参照の問題を解決することが難しいためです。あまり使用されていませんが、それでも学ぶ価値があります。
public class Test { private Object obj; Public static void main(){ Test t1=new Test(); Test t2=new Test(); t1.obj=t2; t2.obj=t1; t1=null; t2=null; //如果对象在这行发生gc,那么t1和t2对象是否能被回收 System.gc(); } }
到達可能性分析の基本的な考え方は、「GC ルート」と呼ばれるいくつかのオブジェクトを開始点として使用し、これらのノードから検索を開始し、直接または間接的な参照関係を持つオブジェクトを検索します。これらのオブジェクトはチェーンの形で結合され、参照チェーンとも呼ばれる「関係ネットワーク」を形成します。最後に、ガベージ コレクターは、この関係ネットワークにないいくつかのオブジェクトを収集します。図に示すように:
GC Roots オブジェクトに接続されているオブジェクトは確実に生きているオブジェクトであり、右側の die オブジェクトは GCROOTS とは何の関係もないため、リサイクル可能なオブジェクトとしてマークされます。現在、主流の商用仮想マシンは同様の方法を使用しています。では、「GC ルート」として使用できるオブジェクトは何でしょうか? Javaでは「GCルート」として利用できるオブジェクトは4種類あります
1:スタックフレーム内のオブジェクトを参照する(第1章の名詞)。 (スタック内)
2: 静的プロパティによって参照されるオブジェクト。 (メソッド領域内)
3: 定数によって参照されるオブジェクト。 (メソッド領域内)
4: ローカル メソッド スタック内の JNI によって参照されるオブジェクト。 (ローカルメソッドスタック内)
2. オブジェクトの二次リサイクル
オブジェクトにマークが付いていると言いましたが、マークされていれば必ずリサイクルされるということではないでしょうか? Object クラスには Finalize() メソッドがあることを覚えているかどうかはわかりませんが、すべてのクラスは Object クラスを継承するため、このメソッドはデフォルトで実装されています。
finalize の動作原理は次のようになります。ガベージ コレクターがオブジェクトによって占有されているストレージ領域を解放する準備ができると、最初に Finalize() が呼び出され、次のガベージ コレクション プロセス中にのみ、オブジェクトのメモリが実際に解放されます。したがって、finalize() を使用すると、ガベージ コレクション中にいくつかの重要なクリーニング作業を実行できます。コレクション System.gc() の実行時などに自動的に呼び出されます。
3. Finalize メソッドを明示的に呼び出す
このメソッドの目的は、オブジェクトがリサイクルされる前に、オブジェクトの Finalize() メソッドが呼び出されるということです。
概要: 簡単に言うと、オブジェクトは初めてマークされ、次の GC の前にオブジェクトの Finalize() メソッドが実行されます。 Finalize()メソッドを実行する際、オブジェクトがfinalize()メソッドを実装しているかどうかを判定し、実装されていない場合は直接クリアし、オブジェクトはfinalizeメソッドを実行するキューに入れられます。 2 回目のマーク
Java ルート検索アルゴリズムで判断 オブジェクトのアクセス可能性は、必ずしも到達不能なオブジェクトをクリーンアップする必要があることを意味するわけではありません。現時点では試用期間があり、オブジェクトが死んだと真に判断するには、少なくとも 2 つのマーキング プロセスを経る必要があります。ルート検索の実行後に GC ルートに関連付けられた参照チェーンが存在しないことが判明した場合は、オブジェクトはそのプロセスを実行します。フィルタリングの条件は、オブジェクトが Finalize() メソッドをカバーしていない場合、または Finalize() メソッドを実行する必要があるかどうかです。仮想マシンによって呼び出された場合、仮想マシンは両方の状況を「実行する必要はありません」として扱います。
つまり、オブジェクトが Finalize() メソッドをオーバーライドすると、そのオブジェクトは Finalize() メソッドを実行する必要があると判断され、そのオブジェクトは F-Queue キューに置かれ、その後、仮想マシンによって自動的に作成された優先度の低いファイナライザー スレッドが実行されます。ここでのいわゆる実行とは、仮想マシンがこのメソッドを開始しますが、実行が完了するまで待つことを約束するものではないことを意味します。この理由: オブジェクトの Finalize() メソッドでの実行が遅い場合、または無限ループが発生した場合 (極端な場合)、F-Queue キュー内の他のオブジェクトが永続的に待機状態になったり、さらにはメモリ全体をリサイクルするシステムがクラッシュします。 Finalize() メソッドは、オブジェクトが死の運命から逃れる最後のチャンスです。その後、オブジェクトが Finalize() で自身を正常に保存したい場合、GC はそのオブジェクトを F キューにマークします。 ---- 参照チェーン上の何かと再関連付けする限り、オブジェクトがこの時点でエスケープされない場合、2 回目にマークされたときに「すぐにリサイクルされる」コレクションから削除されます。 、リサイクルされます。コード例: 「Java 仮想マシンの詳細」の対応する章を参照してください
以上がJava でのリサイクルされたオブジェクトのマーキングとオブジェクトの二次マーキング プロセスの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

PHPが多くのWebサイトよりも優先テクノロジースタックである理由には、その使いやすさ、強力なコミュニティサポート、広範な使用が含まれます。 1)初心者に適した学習と使用が簡単です。 2)巨大な開発者コミュニティと豊富なリソースを持っています。 3)WordPress、Drupal、その他のプラットフォームで広く使用されています。 4)Webサーバーとしっかりと統合して、開発の展開を簡素化します。
