请解释jvm中Xms和Xmx参数的使用。它们的默认值是什么?
当前回答
您可以在IDE中指定它。例如,对于运行配置→VM参数中的Eclipse。您可以输入-Xmx800m -Xms500m as
其他回答
运行命令java -X,你将得到所有-X选项的列表:
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
-X选项是非标准的,如果有更改,恕不另行通知。
我希望这将帮助您理解Xms、Xmx以及许多其他最重要的东西。:)
标志Xmx指定Java虚拟机(JVM)的最大内存分配池,而Xms指定初始内存分配池。
这意味着您的JVM将以Xms大小的内存量启动,并且能够使用最大Xmx大小的内存量。例如,启动如下所示的JVM将使用256 MB内存,并允许进程使用最多2048 MB内存:
java -Xms256m -Xmx2048m
内存标志还可以指定不同的大小,例如千字节、兆字节等等。
-Xmx1024k
-Xmx512m
-Xmx8g
Xms标志没有默认值,Xmx通常的默认值是256 MB。这些标志的常见用途是当您遇到java.lang.OutOfMemoryError时。
在使用这些设置时,请记住这些设置是针对JVM的堆的,并且JVM可以并且将使用比分配给堆的大小更多的内存。来自Oracle的文档:
请注意,JVM使用的内存不仅仅是堆。例如,Java方法、线程堆栈和本机句柄分配在与堆分开的内存中,以及JVM内部数据结构。
-Xms是启动时的初始堆大小,但是,在工作过程中,由于用户不活动或GC迭代,堆大小可能小于-Xms。 这不是所需的堆大小的最小值。
-Xmx是堆的最大大小
这个问题本身已经在上面讨论过了。 只是添加了部分默认值。
对于http://docs.oracle.com/cd/E13150_01/jrockit_jvm/jrockit/jrdocs/refman/optionX.html
Xmx的默认值取决于平台和系统中可用的内存量。
您可以在IDE中指定它。例如,对于运行配置→VM参数中的Eclipse。您可以输入-Xmx800m -Xms500m as
推荐文章
- 到底是什么导致了堆栈溢出错误?
- 为什么Android工作室说“等待调试器”如果我不调试?
- Java:路径vs文件
- ExecutorService,如何等待所有任务完成
- Maven依赖Servlet 3.0 API?
- 如何在IntelliJ IDEA中添加目录到应用程序运行概要文件中的类路径?
- getter和setter是糟糕的设计吗?相互矛盾的建议
- Android room persistent: AppDatabase_Impl不存在
- Java的String[]在Kotlin中等价于什么?
- Intellij IDEA上的System.out.println()快捷方式
- 使用Spring RestTemplate获取JSON对象列表
- Spring JPA选择特定的列
- URLEncoder不能翻译空格字符
- Java中的super()
- 如何转换JSON字符串映射<字符串,字符串>与杰克逊JSON