Inhaltsverzeichnis
HotSpot JVM Collector" >HotSpot JVM Collector
Serial (Serial GC) Collector " >Serial (Serial GC) Collector
ParNew (Parallel GC) Sammler " >ParNew (Parallel GC) Sammler
Parallel-Scavenge-Sammler (Parallel-Recycling-GC) " >Parallel-Scavenge-Sammler (Parallel-Recycling-GC)
Serial Old (Serial GC) Collector " >Serial Old (Serial GC) Collector
Parallel Old (Parallel GC) Collector " >Parallel Old (Parallel GC) Collector
CMS (Concurrent GC) Collector" >CMS (Concurrent GC) Collector
G1 Collector" >G1 Collector
Zusammenfassung der Garbage-Collector-Parameter " > Zusammenfassung der Garbage-Collector-Parameter
Heim Java javaLernprogramm Java Virtual Machine Learning – Garbage Collector

Java Virtual Machine Learning – Garbage Collector

Feb 17, 2017 am 10:42 AM

HotSpot JVM Collector

Oben gibt es 7 Kollektoren, die in zwei Blöcke unterteilt sind. Der obere ist der Kollektor der neuen Generation und der untere ist der Kollektor der alten Generation. Besteht eine Verbindung zwischen zwei Kollektoren, können diese gemeinsam genutzt werden.

Serial (Serial GC) Collector

Serial Collector ist ein Single-Threaded-Collector der neuen Generation Ausführung mithilfe eines Kopieralgorithmus. Während der Garbage Collection müssen alle anderen Arbeitsthreads (Benutzerthreads) angehalten werden. Es ist der Standardkollektor der neuen Generation im JVM-Client-Modus. In einer Umgebung, die auf eine einzelne CPU beschränkt ist, hat der serielle Kollektor keinen Thread-Interaktions-Overhead, sodass er natürlich die höchste Single-Thread-Sammlungseffizienz erzielen kann, indem er sich auf die Speicherbereinigung konzentriert.

ParNew (Parallel GC) Sammler

ParNew Sammler ist eigentlich eine Seriensammlung. Ein Multi -Thread-Version des Kollektors, die sich genauso verhält wie der serielle Kollektor, außer dass sie mehrere Threads für die Garbage Collection verwendet.

Parallel-Scavenge-Sammler (Parallel-Recycling-GC)

Parallel-Scavenge-Sammler auch Neu Generierungskollektor, der auch ein Kollektor ist, der einen Kopieralgorithmus und einen parallelen Multithread-Kollektor verwendet. Das Merkmal des parallelen Scavenge-Kollektors ist, dass sein Fokus sich von anderen Kollektoren unterscheidet. Der Fokus von Kollektoren wie CMS liegt darauf, die Pausenzeit des Benutzerthreads während der Speicherbereinigung so weit wie möglich zu verkürzen, während das Ziel des parallelen Scavenge-Kollektors ist besteht darin, einen realisierbaren kontrollierten Durchsatz zu erreichen. Durchsatz = Programmlaufzeit/(Programmlaufzeit + Garbage Collection-Zeit), die virtuelle Maschine lief insgesamt 100 Minuten. Unter diesen dauert die Speicherbereinigung 1 Minute und der Durchsatz beträgt 99 %.

Serial Old (Serial GC) Collector


Serial Old ist die Version des Serial Collectors der alten Generation. Es verwendet auch einen einzelnen Thread zur Durchführung der Sammlung und verwendet den „Mark-Sort“-Algorithmus. Wird hauptsächlich in virtuellen Maschinen im Client-Modus verwendet.

Parallel Old (Parallel GC) Collector

Parallel Old ist die Version der alten Generation des Parallel Scavenge Collectors, die Multithreading und „Mark-Collation“-Algorithmus verwendet.

CMS (Concurrent GC) Collector

CMS (Concurrent Mark Sweep) Collector ist eine Methode, um die kürzeste Erfassungszeit zu erreichen Die Pausenzeit ist der Zielkollektor. Der CMS-Collector wird auf Basis des „Mark-Clear“-Algorithmus implementiert. Der gesamte Collection-Prozess ist grob in 4 Schritte unterteilt:

①.Anfangsmarkierung (CMS-Anfangsmarkierung)

②.Gleichzeitige Markierung (CMS-Konkurrenzmarkierung)

③ Bemerkung (CMS-Bemerkung)

④.Gleichzeitiger Sweep (CMS-gleichzeitiger Sweep)

Die beiden Schritte des ersten Markierens und erneuten Markierens erfordern immer noch das Anhalten anderer Benutzerthreads. Die anfängliche Markierung markiert nur die Objekte, mit denen GC ROOTS direkt in Verbindung gebracht werden kann, was sehr schnell ist. Die gleichzeitige Markierungsphase ist die Phase des GC ROOTS-Root-Suchalgorithmus, die bestimmt, ob das Objekt aktiv ist. In der Neumarkierungsphase werden die Markierungsdatensätze des Teils der Objekte korrigiert, die sich aufgrund der fortgesetzten Ausführung des Benutzerprogramms während der gleichzeitigen Markierungsperiode geändert haben. Die Pausenzeit in dieser Phase ist etwas länger als in der anfänglichen Markierungsphase , aber kürzer als die gleichzeitige Markierungsphase.

Aufgrund der zeitaufwändigsten gleichzeitigen Markierungs- und gleichzeitigen Löschprozesse im gesamten Prozess kann der Collector-Thread mit dem Benutzer-Thread zusammenarbeiten, also insgesamt der Speicher des CMS-Collectors Der Recyclingprozess wird gleichzeitig mit dem Benutzerthread ausgeführt.

Vorteile des CMS-Kollektors: gleichzeitige Erfassung, geringe Pausen, aber CMS ist alles andere als perfekt. Der Kollektor weist hauptsächlich drei wesentliche Mängel auf:

Der CMS-Kollektor reagiert sehr empfindlich auf CPU-Ressourcen. In der gleichzeitigen Phase wird der Benutzerthread zwar nicht angehalten, es werden jedoch CPU-Ressourcen belegt, das Referenzprogramm wird langsamer und der Gesamtdurchsatz nimmt ab. Die Standardanzahl der von CMS gestarteten Recycling-Threads beträgt: (Anzahl der CPUs + 3) / 4.

Der CMS-Kollektor kann schwebenden Müll nicht verarbeiten, und es kann zu einem „Concurrent Mode Failure“ kommen, der nach dem Ausfall zu einem weiteren vollständigen GC führen kann. Da der Benutzerthread während der gleichzeitigen Bereinigungsphase von CMS weiterhin ausgeführt wird, wird während der Ausführung und Aufwärmung des Programms weiterhin neuer Müll generiert. Dieser Teil des Mülls erscheint nach dem Markierungsprozess nicht in dieser Sammlung und muss verarbeitet werden Warten Sie auf den nächsten GC. Bereinigen Sie es. Dieser Teil des Mülls wird „schwebender Müll“ genannt. Dies liegt auch daran, dass der Benutzer-Thread während der Garbage-Collection-Phase noch ausgeführt werden muss.
Das heißt, es muss ausreichend Speicherplatz für die Verwendung durch den Benutzer-Thread reserviert werden, sodass der CMS-Kollektor nicht warten kann, bis die alte Generation fast vollständig ist Wie bei anderen Sammlern muss vor dem Sammeln ein Teil des Speicherplatzes für den Programmbetrieb während der gleichzeitigen Sammlung reserviert werden. Unter den Standardeinstellungen wird der CMS-Kollektor aktiviert, wenn 68 % des Speicherplatzes in der alten Generation verwendet werden. Sie können auch einen Triggerprozentsatz über den Wert des Parameters -XX:CMSInitiatingOccupancyFraction angeben, um die Anzahl der Speicherrecyclingzeiten zu reduzieren und zu verbessern Leistung. Wenn der während des CMS-Betriebs reservierte Speicher die Anforderungen anderer Threads des Programms nicht erfüllen kann, tritt ein „Concurrent Mode Failure“-Fehler auf. Zu diesem Zeitpunkt startet die virtuelle Maschine einen Sicherungsplan: Aktivieren Sie vorübergehend den Serial Old Collector, um erneut zu arbeiten. Sammeln Sie Müll in der alten Generation, sodass die Pause sehr lang ist. Daher führt eine zu hohe Einstellung des Parameters -XX:CMSInitiatingOccupancyFraction leicht zu einem „Concurrent Mode Failure“-Fehler und verringert die Leistung.

Der letzte Nachteil besteht darin, dass CMS ein Sammler ist, der auf dem „Mark-Clear“-Algorithmus basiert. Nach dem Sammeln mit dem „Mark-Clear“-Algorithmus wird eine große Menge an Fragmenten generiert. Wenn zu viele Speicherplatzfragmente vorhanden sind, führt dies zu großen Problemen bei der Objektzuweisung. Beispielsweise kann der Speicherplatz bei großen Objekten keinen zusammenhängenden Speicherplatz für die Zuweisung finden und muss im Voraus eine vollständige GC auslösen. Um dieses Problem zu lösen, stellt der CMS-Kollektor einen Schalterparameter -XX:UseCMSCompactAtFullCollection bereit, der zum Hinzufügen eines Defragmentierungsprozesses nach der vollständigen GC verwendet wird. Sie können auch den Parameter -XX:CMSFullGCBeforeCompaction verwenden, um festzulegen, wie oft eine unkomprimierte vollständige Ausführung durchgeführt werden soll GC, gefolgt von einem Defragmentierungsprozess.


G1 Collector

Der G1-Kollektor (Garbage First) ist ein neuer Kollektor, der von JDK1.7 bereitgestellt wird. Der G1-Kollektor basiert auf dem „Mark-Complement“-Algorithmus, was bedeutet, dass er keine Speicherfragmentierung erzeugt. Ein weiteres Merkmal besteht darin, dass die vorherigen Collectors die gesamte neue Generation oder die alte Generation sammelten, während G1 den gesamten Java-Heap (einschließlich der neuen Generation und der alten Generation) sammelte.


Zusammenfassung der Garbage-Collector-Parameter

-XX:+

-XX:-

-XX:

-XX:


Parameter Beschreibung

-XX:+UseSerialGC

Der Standardwert für die Ausführung von Jvm im Client-Modus. Nach dem Einschalten dieses Schalters wird die Collector-Kombination aus Serial + Serial Old für die Speicherwiederverwendung verwendet
-XX:+UseParNewGC Nachdem Sie diesen Schalter aktiviert haben, verwenden Sie den ParNew + Serial Old Collector für die Speicherbereinigung
-XX:+UseConcMarkSweepGC Verwenden Sie ParNew + CMS + Serial Old Collector-Kombination für Speicherrecycling, Serial Old erscheint als CMS " Gleichzeitig Der Fallback-Kollektor wird nach einem „Mode Failure“-Fehler verwendet.
-XX:+UseParallelGC Der Standardwert für die Ausführung von Jvm im Servermodus. Verwenden Sie nach dem Einschalten dieses Schalters die Kombination Parallel Scavenge + Serial Old Collector zum Recycling
-XX:+UseParallelOldGC Verwenden Sie Parallel Scavenge + Parallel Alte Sammlerkombination zum Recycling
-XX:SurvivorRatio Das Kapazitätsverhältnis des Eden-Bereichs zum Survivor-Bereich in der neuen Generation, der Standardwert ist 8, was Eden:Subrvivor = 8:1 bedeutet
-XX:PretenureSizeThreshold wird nach dem Festlegen dieses Parameters direkt auf die Größe des Objekts der alten Generation heraufgestuft , Objekte, die größer als dieser Parameter sind, werden direkt zugewiesen Zuweisung der alten Generation
-XX:MaxTenuringThreshold Auf das Alter heraufgestuft Bei Objekten der alten Generation wird das Alter nach jedem Minor GC um 1 erhöht, und wenn es den Wert dieses Parameters überschreitet, tritt es in das alte Alter ein
-XX:UseAdaptiveSizePolicy Passen Sie die Größe jedes Bereichs im Java-Heap und das Alter des Eintritts in die alte Generation dynamisch an
-XX :+HandlePromotionFailure Ob das zugelassen werden soll Neue Generation zum Sammeln von Garantien. Wenn ein weiterer Überlebensraum nicht ausreicht, wird er direkt in der alten Generation beibehalten, nachdem ein kleinerer GC durchgeführt wurde
-XX:ParallelGCThreads Set die Anzahl der Threads für parallele GC für Speicherrecycling
-XX:GCTimeRatio Das Verhältnis der GC-Zeit zur Gesamtzeit ist 99, was bedeutet, dass 1 % der GC-Zeit zulässig ist, nur gültig bei Verwendung des Parallel Scavenge Collector
-XX:MaxGCPauseMillis Legen Sie die maximale Pausenzeit von GC fest, gültig unter dem Parallel Scavenge Collector
-XX:CMSInitiatingOccupancyFraction Stellen Sie den CMS-Kollektor so ein, dass er die Speicherbereinigung startet, nachdem der Speicherplatz der alten Generation verwendet wurde. Der Standardwert beträgt 68 %, nur gültig für den CMS-Kollektor, -XX:CMSInitiatingOccupancyFraction=70
-XX:+UseCMSCompactAtFullCollection
Da der CMS-Collector dies tut Fragmente generieren, dieser Parameter legt fest, ob nach dem Garbage Collector ein Speicherdefragmentierungsprozess erforderlich ist. Er ist nur gültig, wenn der CMS-Collector
-XX:+CMSFullGCBeforeCompaction verwendet wird
Stellen Sie den CMS-Kollektor so ein, dass er nach mehreren Garbage Collections einen Speicherdefragmentierungsprozess durchführt. Wird normalerweise mit dem Parameter „UseCMSCompactAtFullCollection“ zur Optimierung des primitiven Typs verwendet >-XX:+DisableExplicitGC
Ob die manuelle System.gc deaktiviert werden soll
-XX:+CMSParallelRemarkEnabled
Markierungspause reduzieren
-XX: LargePageSizeInBytes Die Größe der Speicherseite kann nicht zu groß eingestellt werden, was sich auf die Größe von Perm auswirkt, -XX:LargePageSizeInBytes=128m


Standard-GC für Client- und Servermodus




  新生代GC方式 老年代和持久GC方式

Client

Serial 串行GC Serial Old 串行GC
Server Parallel Scavenge  并行回收GC Parallel Old 并行GC
GC-Methode der neuen Generation
Alte Generation und PersistenzGenerationGC-Methode
ClientSerial Serial GC Serial Old Serial GC
ServerParallel Scavenge Parallel Scavenge Parallel Alt Parallel GC


Sun/oracle JDK GC组合方式




  新生代GC方式 老年代和持久GC方式
  新生代GC方式 老年代和持久GC方式

-XX:+UseSerialGC

Serial 串行GC Serial Old 串行GC
-XX:+UseParallelGC Parallel Scavenge  并行回收GC Serial Old  并行GC
-XX:+UseConcMarkSweepGC ParNew 并行GC CMS 并发GC
当出现“Concurrent Mode Failure”时
采用Serial Old 串行GC
-XX:+UseParNewGC ParNew 并行GC Serial Old 串行GC
-XX:+UseParallelOldGC Parallel Scavenge  并行回收GC Parallel Old 并行GC
-XX:+UseConcMarkSweepGC
-XX:+UseParNewGC
Serial 串行GC CMS 并发GC 
当出现“Concurrent Mode Failure”时
采用Serial Old 串行GC
-XX:+UseSerialGC

Serial 串行GC Serial Old 串行GC
-XX:+Parallel Scavenge  并行回收GC Serial Old  并行GC
-XX:+UseConcMarkSweepGC ParNew 并行GC CMS 并发GC
当出现„Concurrent Mode Failure“采用Serial Old 串行GC
-XX:+UseParNewGC ParNew 并行GC Serial Old 串行GC
-XX:+UseParallelOldGC Parallel Scavenge  并行回收GC Parallel Old 并行GC
-XX:+UseConcMarkSweepGC

-XX:+UseParNewGC

Serial 串行GC CMS 并发GC 当出现„Concurrent Mode Failure“时

采用Serial Old 串行GC


 以上就是Java虚拟机学习 - 垃圾收集器的内容,更多相关内容请关注注PHP中文网 (www.php.cn) !
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Perfekte Zahl in Java Perfekte Zahl in Java Aug 30, 2024 pm 04:28 PM

Leitfaden zur perfekten Zahl in Java. Hier besprechen wir die Definition, Wie prüft man die perfekte Zahl in Java?, Beispiele mit Code-Implementierung.

Zufallszahlengenerator in Java Zufallszahlengenerator in Java Aug 30, 2024 pm 04:27 PM

Leitfaden zum Zufallszahlengenerator in Java. Hier besprechen wir Funktionen in Java anhand von Beispielen und zwei verschiedene Generatoren anhand ihrer Beispiele.

Weka in Java Weka in Java Aug 30, 2024 pm 04:28 PM

Leitfaden für Weka in Java. Hier besprechen wir die Einführung, die Verwendung von Weka Java, die Art der Plattform und die Vorteile anhand von Beispielen.

Smith-Nummer in Java Smith-Nummer in Java Aug 30, 2024 pm 04:28 PM

Leitfaden zur Smith-Zahl in Java. Hier besprechen wir die Definition: Wie überprüft man die Smith-Nummer in Java? Beispiel mit Code-Implementierung.

Fragen zum Java Spring-Interview Fragen zum Java Spring-Interview Aug 30, 2024 pm 04:29 PM

In diesem Artikel haben wir die am häufigsten gestellten Fragen zu Java Spring-Interviews mit ihren detaillierten Antworten zusammengestellt. Damit Sie das Interview knacken können.

Brechen oder aus Java 8 Stream foreach zurückkehren? Brechen oder aus Java 8 Stream foreach zurückkehren? Feb 07, 2025 pm 12:09 PM

Java 8 führt die Stream -API ein und bietet eine leistungsstarke und ausdrucksstarke Möglichkeit, Datensammlungen zu verarbeiten. Eine häufige Frage bei der Verwendung von Stream lautet jedoch: Wie kann man von einem Foreach -Betrieb brechen oder zurückkehren? Herkömmliche Schleifen ermöglichen eine frühzeitige Unterbrechung oder Rückkehr, aber die Stream's foreach -Methode unterstützt diese Methode nicht direkt. In diesem Artikel werden die Gründe erläutert und alternative Methoden zur Implementierung vorzeitiger Beendigung in Strahlverarbeitungssystemen erforscht. Weitere Lektüre: Java Stream API -Verbesserungen Stream foreach verstehen Die Foreach -Methode ist ein Terminalbetrieb, der einen Vorgang für jedes Element im Stream ausführt. Seine Designabsicht ist

Zeitstempel für Datum in Java Zeitstempel für Datum in Java Aug 30, 2024 pm 04:28 PM

Anleitung zum TimeStamp to Date in Java. Hier diskutieren wir auch die Einführung und wie man Zeitstempel in Java in ein Datum konvertiert, zusammen mit Beispielen.

Java -Programm, um das Kapselvolumen zu finden Java -Programm, um das Kapselvolumen zu finden Feb 07, 2025 am 11:37 AM

Kapseln sind dreidimensionale geometrische Figuren, die aus einem Zylinder und einer Hemisphäre an beiden Enden bestehen. Das Volumen der Kapsel kann berechnet werden, indem das Volumen des Zylinders und das Volumen der Hemisphäre an beiden Enden hinzugefügt werden. In diesem Tutorial wird erörtert, wie das Volumen einer bestimmten Kapsel in Java mit verschiedenen Methoden berechnet wird. Kapselvolumenformel Die Formel für das Kapselvolumen lautet wie folgt: Kapselvolumen = zylindrisches Volumenvolumen Zwei Hemisphäre Volumen In, R: Der Radius der Hemisphäre. H: Die Höhe des Zylinders (ohne die Hemisphäre). Beispiel 1 eingeben Radius = 5 Einheiten Höhe = 10 Einheiten Ausgabe Volumen = 1570,8 Kubikeinheiten erklären Berechnen Sie das Volumen mithilfe der Formel: Volumen = π × R2 × H (4

See all articles