Maison > Java > javaDidacticiel > Comment augmenter la taille de la pile Java et éviter StackOverflowError ?

Comment augmenter la taille de la pile Java et éviter StackOverflowError ?

DDD
Libérer: 2024-12-25 18:58:13
original
142 Les gens l'ont consulté

How to Increase Java Stack Size and Avoid StackOverflowError?

Comment augmenter la taille de la pile Java (paramètre Xss)

Pour augmenter la capacité de la pile d'exécution dans la JVM, utilisez le '-Xss ' indicateur de ligne de commande avec une valeur appropriée. Pour le programme 'TT' (1<<15), '-Xss4m' suffit :

$ javac TT.java
$ java -Xss4m TT
Copier après la connexion

Dépendance d'implémentation des indicateurs '-X...'

Notez que les indicateurs '-X...' sont spécifiques à l'implémentation. Dans la version Java fournie, l'indicateur « -Xss » contrôle la taille de la pile pour tous les threads.

Allocation de pile spécifique au thread

Alternativement, vous pouvez attribuer une allocation généreuse taille de la pile sur un thread particulier à l'aide de la méthode java.lang.Thread.stackSize(). Cette approche est avantageuse car elle évite le gaspillage de mémoire pour les threads avec des exigences de pile modestes.

Détermination des exigences de pile

Pour évaluer la taille de pile nécessaire pour un programme, exécutez-le de manière itérative avec des tailles de pile croissantes jusqu'à ce qu'il s'exécute avec succès sans 'StackOverflowError'. Pour le programme « TT », les tailles de pile ont été déterminées comme suit :

-Xss4m: suffices for (1 << 15)
-Xss5m: suffices for (1 << 17)
...
-Xss515m: suffices for (1 << 25)
Copier après la connexion

Phénomène d'exigence de pile non déterministe

L'exigence de pile peut présenter un comportement non déterministe en raison de facteurs tels que garbage collection et timing d’exécution JIT. Pour calculer précisément la profondeur de pile atteinte, reportez-vous à la réponse ci-dessous (en utilisant Javassist).

Implémentations alternatives

Envisagez des algorithmes alternatifs avec moins de consommation de pile. Pour la fonction « fact », une implémentation itérative peut être utilisée pour éviter la récursion et réduire l'utilisation de la pile :

public class TTIterative {
    // ... implementation ...
}
Copier après la connexion

Considérations BigInteger

La fonction « fact » ne peut pas calculez des factorielles précises pour les nombres supérieurs à 65 en utilisant le type de données « long » en raison d'un débordement. La refactorisation de la fonction pour renvoyer un « BigInteger » résout ce problème et fournit des résultats exacts pour des entrées plus volumineuses.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal