Heim  >  Artikel  >  Java  >  Was sind die häufigsten Speicherverlustszenarien in Java?

Was sind die häufigsten Speicherverlustszenarien in Java?

王林
王林Original
2024-04-13 18:39:02439Durchsuche

Zu den häufigsten Speicherverlustszenarien in Java gehören: Halten von Verweisen auf externe Objekte, statische Verweise, ungültige Listener, Thread-lokale Variablen und Zirkelverweise. Zu den häufigsten Speicherverlustszenarien in Anwendungsservern gehören Threads, die Verweise auf Servlet-Objekte enthalten, statische Halter, die Verweise auf dauerhafte Verbindungen enthalten, und Listener, die nicht aus Komponenten entfernt werden.

Was sind die häufigsten Speicherverlustszenarien in Java?

Häufige Speicherleckszenarien in Java

Speicherlecks sind ein schwerwiegender Fehler in der Softwareentwicklung, der im Laufe der Zeit zu Anwendungsabstürzen oder Leistungseinbußen führen kann. Im Folgenden sind die häufigsten Speicherverlustszenarien in Java aufgeführt:

1. Halten eines Verweises auf ein externes Objekt

Wenn ein Objekt einen Verweis auf ein externes Objekt enthält, kann die JVM das externe Objekt nicht sammeln, wenn dies nicht der Fall ist in Benutzung. . Zum Beispiel:

class Outer {
    private Inner inner;

    public Outer() {
        inner = new Inner();  // 持有对 Inner 的引用
    }
}

class Inner {
    // ...
}

2. Statische Referenzen

Statische Variablen werden im permanenten Speicher der JVM gespeichert und niemals durch Müll gesammelt. Wenn eine statische Variable einen Verweis auf ein Objekt enthält, kann das Objekt nicht durch Garbage Collection erfasst werden. Beispiel:

public class Example {
    private static List<Object> objects = new ArrayList<>();

    public static void main(String[] args) {
        objects.add(new Object());
    }
}

3. Ungültiger Listener

Ein Speicherverlust tritt auf, wenn ein Listener nicht mehr verwendet wird, aber immer noch an eine Ereignisquelle angeschlossen ist. Zum Beispiel:

import javax.swing.*;

public class ListenerLeak {
    private JButton button;

    public ListenerLeak() {
        button = new JButton();
        button.addActionListener(e -> {
            // ...
        });
    }

    // 忘记从按钮中移除监听器
}

4. Thread-lokale Variablen

Thread-lokale Variablen werden im Thread-lokalen Speicher (TLS) jedes Threads gespeichert und werden nicht durch Müll gesammelt, solange der Thread aktiv ist. Wenn Sie Thread-lokale Variablen in einem abgeschlossenen Thread verwenden, kann dies zu einem Speicherverlust führen. Zum Beispiel:

public class ThreadLocalLeak {
    private static ThreadLocal<Object> threadLocal = new ThreadLocal<>();

    public static void main(String[] args) {
        Thread thread = new Thread(() -> {
            threadLocal.set(new Object());  // 在线程中设置值
        });
        thread.start();
        thread.interrupt();  // 中断线程

        // 线程局部存储未得到清理
    }
}

5. Zirkelverweis

Ein Zirkelverweis liegt vor, wenn zwei oder mehr Objekte aufeinander verweisen. Dies führt dazu, dass die JVM nicht erkennt, dass sie nicht mehr verwendet werden, was zu einem Speicherverlust führt. Zum Beispiel:

public class CycleReference {
    private CycleReference other;

    public CycleReference() {
        other = new CycleReference();
        other.other = this;  // 循环引用
    }
}

Praktischer Fall

Speicherlecks in Anwendungsservern

Das Folgende sind typische Speicherleckszenarien in Anwendungsservern:

  1. Threads speichern Verweise auf Servlet-Objekte, auch nachdem das Servlet abgeschlossen ist.
  2. Statische Inhaber (z. B. Datenbankverbindungspools) behalten Verweise auf dauerhafte Verbindungen, auch wenn diese Verbindungen nicht mehr benötigt werden.
  3. Der Listener wurde nicht aus der Komponente entfernt, sodass die Referenz des Listeners beibehalten wurde.

Sie können das Risiko von Speicherlecks in Ihren Java-Anwendungen reduzieren, indem Sie häufige Speicherleckszenarien verstehen und geeignete Codierungspraktiken anwenden, um deren Stabilität und Leistung sicherzustellen.

Das obige ist der detaillierte Inhalt vonWas sind die häufigsten Speicherverlustszenarien 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