Erhöhung der Java-Stack-Größe für größere Aufrufstapel
Die Java Virtual Machine (JVM) verwaltet einen Laufzeit-Aufrufstapel für jeden Thread. Wenn die Stapelgröße nicht ausreicht, um einen tiefen Aufrufstapel zu verarbeiten, tritt ein StackOverflowError auf. Um diese Stapelgröße für die Aufnahme größerer Aufrufstapel zu erweitern, nutzen Sie das Java-Befehlszeilenflag -Xss....
Zum Beispiel in Ihrem Codeausschnitt:
public class TT { public static long fact(int n) { return n < 2 ? 1 : n * fact(n - 1); } }
Um das zu verarbeiten fact(2^15) Berechnung können Sie Folgendes verwenden:
java -Xss4m TT
Implementierungsspezifisch und Threadspezifische Stack-Konfiguration
Beachten Sie, dass die Flags -X... von der Implementierung abhängig sind. In Ihrem Fall verwenden Sie die JVM von OpenJDK. Darüber hinaus können Sie eine größere Stapelgröße nur für bestimmte Threads angeben und so die Verschwendung von Speicher für Threads vermeiden, die dies nicht benötigen. Dies ist der Verwendung von Java -Xss vorzuziehen....
Schätzen der erforderlichen Stapelgröße
Sie können die genaue Stapelgröße bestimmen, die für Ihr Programm benötigt wird, indem Sie die - Xss-Wert, bis die gewünschten Berechnungen verarbeitet werden, ohne dass ein StackOverflowError auftritt.
Nichtdeterministisch Verhalten
Die Stapelanforderung kann manchmal nichtdeterministisch sein. Faktoren wie Garbage Collection oder JIT-Kompilierung könnten zu diesem Verhalten beitragen.
Alternative Implementierungen: Iterativ vs. rekursiv
Erwägen Sie alternative, weniger stapelintensive Implementierungen Ihrer Algorithmen. Für Ihre Faktenfunktion könnte eine iterative Implementierung weniger anfällig für Stapelüberläufe sein:
public class TTIterative { public static long fact(int n) { if (n < 2) return 1; if (n > 65) return 0; long f = 2; for (int i = 3; i <= n; ++i) { f *= i; } return f; } }
Bedenken Sie, dass die Faktenfunktion aufgrund der Einschränkungen des langen Datentyps keine exakten Fakultäten für Zahlen größer als 65 berechnen kann. Erwägen Sie stattdessen die Rückgabe eines BigInteger, um diese Einschränkung zu überwinden.
Das obige ist der detaillierte Inhalt vonWie kann ich die Java-Stack-Größe erhöhen, um StackOverflowErrors zu verhindern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!