Heim  >  Artikel  >  Java  >  Strings: Garbage Collection und Unveränderlichkeit in Java

Strings: Garbage Collection und Unveränderlichkeit in Java

DDD
DDDOriginal
2024-11-07 08:13:03690Durchsuche

Strings: Garbage Collection and Immutability in Java

In Java spielen Strings aufgrund ihrer Unveränderlichkeit und Internierungseigenschaften eine einzigartige Rolle bei der Speicherverwaltung. Diese Konzepte verbessern nicht nur die Leistung, sondern führen auch Nuancen in den Umgang mit dem Gedächtnis ein, die in Interviews oft unerlässlich sind.

Lassen Sie uns Garbage Collection und Unveränderlichkeit genauer untersuchen, mit Hinweisen dazu, wie der String-Pool und die JVM-Speicherverwaltung mit diesen Konzepten interagieren.

Dieser Beitrag baut auf Konzepten auf, die im vorherigen Artikel über String-Pool und Speicherverwaltung besprochen wurden. Wenn Sie zunächst diesen Artikel lesen, erhalten Sie eine hilfreiche Grundlage für das Verständnis der hier behandelten Themen.


1. String-Garbage-Collection

In Java verhalten sich String-Literale im Hinblick auf die Garbage Collection (GC) anders.

1. Nicht referenzierte Literale im String-Pool

String string3 = "World"; // Stored in String Pool

// A new string is created in the pool due to case-sensitivity
string3 = "WORLD";
  • In diesem Beispiel befindet sich die ursprüngliche „Welt“ immer noch im String-Pool, obwohl String3 neu zugewiesen wurde.

  • Die JVM behält nicht referenzierte Literale im Pool, was eine zukünftige Wiederverwendung ermöglicht, aber diese Literale unterliegen NICHT der Garbage Collection wie normale Heap-Objekte.

2. Heap-Objekte

String str1 = new String("World"); // Stored in Heap

// String Pool reference is used now
// leaving the previous "World" eligible for GC in Heap
str1 = "WORLD";
  • Wenn ein String mit new erstellt wird, geht er auf den Heap statt in den String-Pool.

  • Wenn sich die Referenz ändert, wie bei str1, kann die nicht verwendete „World“-Zeichenfolge im Heap im Müll gesammelt werden, da sie nicht mehr referenziert wird.


2. String-Unveränderlichkeit

Strings in Java sind unveränderlich – sobald sie erstellt wurden, können sie nicht mehr geändert werden. Jede „Änderung“ führt zu einem neuen String-Objekt, anstatt das vorhandene zu ändern.

Praktische Auswirkungen der Unveränderlichkeit

1. Verkettung zur Kompilierzeit (Optimierung mit Literalen)

   String string5 = "This" + "String";
  • Beim Verketten von Literalen optimiert der Java-Compiler, indem er die Verkettung zur Kompilierungszeit durchführt.

  • Der resultierende String („ThisString“) wird direkt im String-Pool gespeichert, wodurch der Heap vollständig vermieden wird.

  • Dieser Vorgang wird auch als Constant Pool Folding bezeichnet.

2. Laufzeitverkettung (keine Optimierung)

   String string1 = "Hello";
   string1 = string1 + "Hello"; // Stored in Heap
  • Wenn ein oder mehrere Operanden Variablen (Nicht-Literale) sind, erfolgt die Verkettung zur Laufzeit, was zu einem Heap-Objekt führt, das sich nicht im String-Pool befindet .

  • Beispiel: Das ursprüngliche „Hello“-Literal bleibt im Pool, während die verkettete „HelloHello“-Zeichenfolge im Heap gespeichert wird, was die Unveränderlichkeit des ursprünglichen „Hello“ bestätigt.

3. Verwendung der concat()-Methode

String string3 = "World"; // Stored in String Pool

// A new string is created in the pool due to case-sensitivity
string3 = "WORLD";
  • Die concat()-Methode führt immer eine Laufzeit-Verkettung durch und platziert die neue Zeichenfolge im Heap, unabhängig davon, ob die Operanden Literale oder Variablen sind.

4. Anwenden der intern()-Methode

String str1 = new String("World"); // Stored in Heap

// String Pool reference is used now
// leaving the previous "World" eligible for GC in Heap
str1 = "WORLD";

Prozess:

  • Zuerst erstellt die concat()-Operation eine neue Zeichenfolge im Heap mit dem Wert „Welt sagt Hallo“, auf den string3 zunächst verweist.

  • Wenn wir intern() aufrufen, prüft es, ob sich dieser Wert bereits im String Pool befindet. Wenn nicht, fügt es den Wert dem Pool hinzu und gibt einen Verweis auf diese gepoolte Instanz zurück.

  • Nach dem Aufruf von intern() zeigt string3 auf die gepoolte Kopie des Strings. Die ursprüngliche Heap-Instanz, jetzt ohne aktive Referenzen, wird für die Speicherbereinigung geeignet, wodurch unnötiger Speicherverbrauch reduziert wird.


Zusammenfassung der wichtigsten Punkte

  • String-Pool-Optimierung: Der String-Pool ist entscheidend für die Speichereinsparung durch die Wiederverwendung von Literalen.
  • Unveränderlichkeit: Unveränderlichkeit macht Strings threadsicher und zuverlässig, kann jedoch beim Ändern von Strings zu zusätzlichen Heap-Objekten führen.
  • Garbage Collection: Nicht referenzierte Literale im Pool werden nicht durch Garbage Collection erfasst, jedochnicht verwendete Heap-basierte Zeichenfolgen.

Durch das Verständnis und die Nutzung dieser Prinzipien können Java-Entwickler speichereffizienteren und leistungsfähigeren Code schreiben.


Verwandte Beiträge

  • Java-Grundlagen
  • Array Interview Essentials
  • Java Memory Essentials
  • Java Keywords Essentials
  • Java OOPs Essentials
  • Collections Framework Essentials

Viel Spaß beim Programmieren!

Das obige ist der detaillierte Inhalt vonStrings: Garbage Collection und Unveränderlichkeit in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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