Réponses:
L'indicateur Xmx
spécifie le pool d'allocation de mémoire maximum pour une machine virtuelle Java (JVM), tandis que Xms
spécifie le pool d'allocation de mémoire initial.
Cela signifie que votre machine virtuelle Java sera démarrée avec une Xms
quantité de mémoire et pourra utiliser un maximum Xmx
de mémoire. Par exemple, le démarrage d'une machine virtuelle Java comme ci-dessous la démarrera avec 256 Mo de mémoire et permettra au processus d'utiliser jusqu'à 2048 Mo de mémoire:
java -Xms256m -Xmx2048m
L'indicateur de mémoire peut également être spécifié dans différentes tailles, telles que des kilo-octets, des mégaoctets, etc.
-Xmx1024k
-Xmx512m
-Xmx8g
L' Xms
indicateur n'a pas de valeur par défaut et a Xmx
généralement une valeur par défaut de 256 Mo. Une utilisation courante de ces drapeaux est lorsque vous rencontrez un java.lang.OutOfMemoryError
.
Lorsque vous utilisez ces paramètres, gardez à l'esprit que ces paramètres sont pour le tas de la JVM et que la JVM peut / utilisera plus de mémoire que la taille allouée au tas. De la documentation d'Oracle :
Notez que la JVM utilise plus de mémoire que le tas. Par exemple, les méthodes Java, les piles de threads et les descripteurs natifs sont alloués dans une mémoire distincte du tas, ainsi que dans les structures de données internes JVM.
OutOfMemoryError
se produira.
-Xms256m
est "256 Mo", et non "256 Mo", car elle utilise des puissances binaires plutôt que des puissances de dix. Voir en.wikipedia.org/wiki/Binary_prefix . En outre, comme un espace inutilisable est réservé pour un pool supplémentaire d'espace Survivor, la quantité de mémoire réellement disponible Runtime.getRuntime().maxMemory()
est inférieure à la valeur spécifiée via -Xmx
Exécutez la commande java -X
et vous obtiendrez une liste de toutes les -X
options:
C:\Users\Admin>java -X
-Xmixed mixed mode execution (default)
-Xint interpreted mode execution only
-Xbootclasspath:<directories and zip/jar files separated by ;>
set search path for bootstrap classes and resources
-Xbootclasspath/a:<directories and zip/jar files separated by ;>
append to end of bootstrap class path
-Xbootclasspath/p:<directories and zip/jar files separated by ;>
prepend in front of bootstrap class path
-Xdiag show additional diagnostic messages
-Xnoclassgc disable class garbage collection
-Xincgc enable incremental garbage collection
-Xloggc:<file> log GC status to a file with time stamps
-Xbatch disable background compilation
-Xms<size> set initial Java heap size.........................
-Xmx<size> set maximum Java heap size.........................
-Xss<size> set java thread stack size
-Xprof output cpu profiling data
-Xfuture enable strictest checks, anticipating future default
-Xrs reduce use of OS signals by Java/VM (see documentation)
-Xcheck:jni perform additional checks for JNI functions
-Xshare:off do not attempt to use shared class data
-Xshare:auto use shared class data if possible (default)
-Xshare:on require using shared class data, otherwise fail.
-XshowSettings show all settings and continue
-XshowSettings:all show all settings and continue
-XshowSettings:vm show all vm related settings and continue
-XshowSettings:properties show all property settings and continue
-XshowSettings:locale show all locale related settings and continue
Les options -X ne sont pas standard et peuvent être modifiées sans préavis.
J'espère que cela vous aidera à comprendre Xms
, Xmx
ainsi que bien d'autres choses qui comptent le plus. :)
Vous pouvez le spécifier dans votre IDE. Par exemple, pour Eclipse dans Run Configurations → Arguments VM . Vous pouvez entrer en -Xmx800m -Xms500m
tant que
La question elle-même a déjà été abordée ci-dessus. Il suffit d'ajouter une partie des valeurs par défaut.
Selon http://docs.oracle.com/cd/E13150_01/jrockit_jvm/jrockit/jrdocs/refman/optionX.html
La valeur par défaut de Xmx dépendra de la plate-forme et de la quantité de mémoire disponible dans le système.
-Xms taille de segment de mémoire initiale pour le démarrage, cependant, pendant le processus de travail, la taille de segment de mémoire peut être inférieure à -Xms en raison de l'inactivité des utilisateurs ou des itérations du GC. Il ne s'agit pas d'une taille de segment minimale requise.
-Xmx taille maximale du tas
-Xmx128m -Xms64m
peut atteindre un pic autour de275m
mem mem RES, mais lors de son utilisation-Xmx128m -Xms128m
peut pic autour de550m
mem mem RES En utilisant Java 8 La meilleure chose est de souligner le GC et de regarder ce qui se passe ...