In diesem Artikel werden hauptsächlich relevante Informationen zur detaillierten Erläuterung des von der Java Virtual Machine verwalteten Speicherlaufzeitdatenbereichs vorgestellt. Freunde in Not können sich auf
Detaillierte Erläuterung des verwalteten Speicherlaufzeitdatenbereichs beziehen durch die Java Virtual Machine.
Übersicht
Wenn die Java Virtual Machine ein Java-Programm ausführt, teilt sie den von ihr verwalteten Speicher in mehrere verschiedene Datenbereiche auf. Diese Bereiche haben ihre eigenen Zwecke sowie den Zeitpunkt der Erstellung und Zerstörung. Einige Bereiche existieren beim Start des Prozesses der virtuellen Maschine, und einige Bereiche werden abhängig vom Start und Ende des Benutzer-Threads erstellt und zerstört.
Programmzähler
Der Programmzähler ist ein kleiner Speicherplatz, der als die vom aktuellen Thread ausgeführten Wörter betrachtet werden kann . Zeilennummernanzeige für Abschnittscode. Im Konzept der virtuellen Maschine Modell ändert der Bytecode-Interpreter den Wert dieses Zählers, um die nächste auszuführende Bytecode-Anweisung, Verzweigung, Schleife und Grundfunktionen wie Sprünge auszuwählen , Ausnahmebehandlung und Thread-Wiederherstellung sind alle auf diesen Zähler angewiesen, um abgeschlossen zu werden.
Wenn der Thread eine Java-Methode ausführt, zeichnet dieser Zähler die Adresse der ausgeführten Bytecode-Anweisung der virtuellen Maschine auf. Wenn der Thread eine native Methode ausführt, ist der Zählerwert leer. Dieser Speicherbereich ist der einzige Bereich, der in der Java Virtual Machine Specification keine OurOfMemoryError-Bedingungen angibt.
Virtual Machine Stack
Wie der Programmzähler ist auch der Java Virtual Machine Stack privat für den Thread und sein Lebenszyklus ist der das Gleiche wie der Thread. Der Stapel der virtuellen Maschine beschreibt das Speichermodell der Java-Methodenausführung. Bei der Ausführung jeder Methode wird ein Stapelrahmen (Stapelrahmen) zum Speichern lokaler -Variablen--Tabellen, Operandenstapel, dynamischer Links und Methoden erstellt und andere Informationen. Der Prozess vom Aufruf bis zum Abschluss der Ausführung jeder Methode entspricht dem Prozess vom Schieben eines Stapelrahmens in den Stapel der virtuellen Maschine bis zum Herausspringen desselben.
Die lokale Variablentabelle speichert verschiedene grundlegende Datentypen (boolean, byte, char, short, int, float, long, double) und Objektreferenzen, die zur Kompilierungszeit und Bytecode-Anweisungsadresse bekannt sind (returnAddress-Typ).
In der Java Virtual Machine-Spezifikation sind für diesen Bereich zwei Ausnahmebedingungen angegeben: Wenn die vom Thread angeforderte Stapeltiefe größer ist als die von der virtuellen Maschine zulässige Tiefe, wird eine StackOverflowError-Ausnahme ausgelöst Der Stapel der virtuellen Maschine kann dynamisch erweitert werden. Eine OutOfMemoryError-Ausnahme wird ausgelöst, wenn während der Erweiterung nicht genügend Arbeitsspeicher beantragt werden kann.
Für 32-Bit-JVM beträgt die Standardgröße 256 KB, während für 64-Bit-JVM die Standardgröße 512 KB beträgt. Sie können den Maximalwert des virtuellen Maschinenstapels über -Xss festlegen. Wenn die Einstellung jedoch zu groß ist, wirkt sich dies auf die Anzahl der Threads aus, die erstellt werden können.
Methodenbereich
Der Methodenbereich ist wie der Java-Heap ein Speicherbereich, der von jedem Thread gemeinsam genutzt wird. Er wird zum Speichern von Klasseninformationen und Konstanten verwendet Von der virtuellen Maschine geladene statische Variablen, vom Just-in-Time-Compiler kompilierter Code und andere Daten.
Gemäß der Java Virtual Machine-Spezifikation wird eine OutOfMemoryError-Ausnahme ausgelöst, wenn der Methodenbereich die Speicherzuweisungsanforderungen nicht erfüllen kann.
Native Method Stack
Native Method Stacks (Native Method Stacks) spielen eine sehr ähnliche Rolle wie der Virtual Machine Stack. Der Unterschied besteht darin, dass der Virtual Machine Stack Java ausführt für die Methodendienste, während der lokale Methodenstapel die von der virtuellen Maschine verwendeten nativen Methoden bereitstellt.
Java-Heap
Der Java-Heap (Java-Heap) ist der größte von der Java Virtual Machine verwaltete Speicherbereich. Dieser Speicherbereich wird beim Start der virtuellen Maschine erstellt und dient ausschließlich der Speicherung von Objektinstanzen. Fast alle Objektinstanzen weisen hier Speicher zu.
Der Java-Heap ist der Hauptbereich für die Garbage-Collection-Verwaltung und wird daher oft als „GC“-Heap bezeichnet.
Gemäß der Java Virtual Machine-Spezifikation kann sich der Java-Heap in einem physisch diskontinuierlichen Speicherbereich befinden, solange er logisch kontinuierlich ist, genau wie unser Festplattenspeicher. Bei der Implementierung kann es entweder als feste Größe oder als skalierbare Implementierung implementiert werden. Die aktuellen gängigen virtuellen Maschinen sind jedoch alle als skalierbar implementiert. (Gesteuert durch -Xmx und -Xms) Wenn im Heap kein Speicher zum Abschließen der Instanzzuweisung vorhanden ist und der Heap nicht mehr erweitert werden kann, wird eine OutOfMemoryError-Ausnahme ausgelöst.
Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in den von der Java Virtual Machine verwalteten Speicherlaufzeitdatenbereich. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!