Risposte:
Il flag Xmx
specifica il pool di allocazione di memoria massimo per una macchina virtuale Java (JVM), mentre Xms
specifica il pool di allocazione di memoria iniziale.
Ciò significa che la tua JVM verrà avviata con una Xms
quantità di memoria e sarà in grado di utilizzare una Xmx
quantità massima di memoria. Ad esempio, l'avvio di una JVM come di seguito la avvierà con 256 MB di memoria e consentirà al processo di utilizzare fino a 2048 MB di memoria:
java -Xms256m -Xmx2048m
Il flag di memoria può anche essere specificato in diverse dimensioni, come kilobyte, megabyte e così via.
-Xmx1024k
-Xmx512m
-Xmx8g
Il Xms
flag non ha un valore predefinito e in Xmx
genere ha un valore predefinito di 256 MB. Un uso comune di queste bandiere è quando si incontra a java.lang.OutOfMemoryError
.
Quando si utilizzano queste impostazioni, tenere presente che queste impostazioni sono per l' heap della JVM e che la JVM può / utilizzerà più memoria rispetto alle dimensioni allocate all'heap. Dalla documentazione di Oracle :
Si noti che JVM utilizza più memoria rispetto al solo heap. Ad esempio metodi Java, stack di thread e handle nativi vengono allocati in memoria separatamente dall'heap, nonché dalle strutture di dati interne JVM.
OutOfMemoryError
si verificherà un errore.
-Xms256m
è "256 MiB", non "256 MB", poiché passa da potenze binarie piuttosto che da potenze di dieci. Vedi en.wikipedia.org/wiki/Binary_prefix . Inoltre, poiché è disponibile uno spazio inutilizzabile per un pool aggiuntivo di spazio Survivor, la quantità di memoria effettivamente disponibile secondo Runtime.getRuntime().maxMemory()
è inferiore al valore specificato tramite -Xmx
Esegui il comando java -X
e otterrai un elenco di tutte le -X
opzioni:
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
Le opzioni -X non sono standard e sono soggette a modifiche senza preavviso.
Spero che questo ti aiuti a capire Xms
, Xmx
così come molte altre cose che contano di più. :)
Puoi specificarlo nel tuo IDE. Ad esempio, per Eclipse in Esegui configurazioni → Argomenti VM . Puoi inserire -Xmx800m -Xms500m
come
La domanda stessa è già stata affrontata sopra. Basta aggiungere parte dei valori predefiniti.
Secondo http://docs.oracle.com/cd/E13150_01/jrockit_jvm/jrockit/jrdocs/refman/optionX.html
Il valore predefinito di Xmx dipenderà dalla piattaforma e dalla quantità di memoria disponibile nel sistema.
-Xms dimensione iniziale dell'heap per l'avvio, tuttavia, durante il processo di lavoro, la dimensione dell'heap può essere inferiore a -Xms causa dell'inattività degli utenti o delle iterazioni GC. Questa non è una dimensione heap minima richiesta.
-Xmx dimensione massima dell'heap
-Xmx128m -Xms64m
può raggiungere il picco di275m
mem RES, ma quando lo si utilizza-Xmx128m -Xms128m
può raggiungere il picco di550m
mem RES Utilizzo di Java 8 La cosa migliore è sottolineare il GC e vedere cosa succede ...