Heim  >  Artikel  >  Java  >  Übersicht über Speicherlecks in Java

Übersicht über Speicherlecks in Java

Y2J
Y2JOriginal
2017-04-21 16:33:461699Durchsuche

Ein wesentlicher Vorteil der Java-Sprache ist ihr Speicherverwaltungsmechanismus. Sie erstellen einfach Objekte und der Garbage Collector von Java hilft Ihnen beim Zuweisen und Freigeben von Speicher. Die tatsächliche Situation ist jedoch nicht so einfach, da es in Java-Anwendungen immer noch zu Speicherlecks kommt.

Im Folgenden wird erklärt, was ein Speicherverlust ist, warum er auftritt und wie wir ihn verhindern können.

 1. Was ist ein Speicherverlust?

Definition von Speicherverlust: Objekte werden von der Anwendung nicht mehr verwendet, aber der Garbage Collector kann sie nicht entfernen, da sie noch referenziert werden.

Um diese Definition zu verstehen, müssen wir zunächst den Zustand des Objekts im Speicher verstehen. Das Bild unten erklärt, was ein nutzloses Objekt ist und was ein nicht referenziertes Objekt ist.

Unbenutzt und nicht referenziert

Wie Sie der obigen Abbildung entnehmen können, gibt es referenzierte Objekte und nicht referenzierte Objekte. Nicht referenzierte Objekte werden vom Garbage Collector gesammelt, referenzierte Objekte jedoch nicht. Ein nicht referenziertes Objekt ist natürlich ein Objekt, das nicht mehr verwendet wird, da kein Objekt mehr darauf verweist. Allerdings sind nutzlose Objekte nicht alle nicht referenzierten Objekte. Einige davon werden zitiert. Es ist diese Situation, die Speicherlecks verursacht.

 2. Warum tritt ein Speicherverlust auf?

Schauen wir uns zunächst das folgende Beispiel an, um zu sehen, warum ein Speicherverlust auftritt. Im folgenden Beispiel bezieht sich Objekt A auf Objekt B. Der Lebenszyklus (t1-t4) von Objekt A ist viel länger als der Lebenszyklus (t2-t3) von Objekt B. Wenn das B-Objekt nicht von der Anwendung verwendet wird, verweist das A-Objekt weiterhin auf das B-Objekt. Auf diese Weise kann der Garbage Collector das B-Objekt nicht aus dem Speicher entfernen, was zu Speicherproblemen führt, denn wenn A auf mehr solcher Objekte verweist, sind mehr nicht referenzierte Objekte vorhanden und verbrauchen Speicherplatz.

Objekt B kann auch viele andere Objekte enthalten, und diese Objekte werden vom Garbage Collector ebenfalls nicht recycelt. Alle diese ungenutzten Objekte verbrauchen weiterhin den zuvor zugewiesenen Speicherplatz.

Object-Life-Time

 3. Wie kann verhindert werden, dass Speicherlecks auftreten?

Hier sind ein paar benutzerfreundliche Vorschläge, die Ihnen helfen, das Auftreten von Speicherverlusten zu verhindern.

  • Achten Sie besonders auf einige Sammlungsobjekte wie HashMap und ArrayList, die häufig zu Speicherverlusten führen. Wenn sie als statisch deklariert werden, ist ihre Lebensdauer so lang wie die der Anwendung.

  • Achten Sie besonders auf das EventMithören und die Rückruffunktion. Ein Listener wird registriert, während er verwendet wird. Die Registrierung wird jedoch nicht aufgehoben, wenn er nicht mehr verwendet wird.

  • „Wenn eine Klasse ihren eigenen Speicher verwaltet, müssen Entwickler auf Speicherlecks achten.“ Normalerweise verweisen einige Mitgliedsvariablen auf andere Objekte und müssen initialisiert werden Leer lassen.

 4. Eine kleine Frage: Warum ist die substirng()-Methode in JDK6 anfällig für Speicherverluste?

Um die obige Frage zu beantworten, möchten Sie vielleicht einen Blick auf Substring() in JDK 6 und 7 werfen.

Das obige ist der detaillierte Inhalt vonÜbersicht über Speicherlecks 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