JVM中的flag设置详解

网友投稿 320 2023-02-20


JVM中的flag设置详解

本文研究的主要是JVM中的flag设置详解的相关内容,具体介绍如下。

一、堆大小设置

-Xmx3550m:设置JVM最大可用内存为3550M。

-Xms3550m:设置JVM初始可用内存为3550M。

-Xmn2g:设置年轻代大小为2G。

-Xss128k:设置每个线程的堆栈大小为128K

-XX:NewSize=4:设置年轻代大小为4

-XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与老年代(除去持久代)的比值为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5

-XX:SurvivorRatio=4:设置年轻代中Eden区与Survivor区的大小比值.设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6

-XX:MaxPermSize=16m:设置持久代大小为16m.

-XX:PretenureSizeThreshold=n,大于n的对象直接放入老年代

-XX:MaxTenuringThreshold=0:设置垃圾最大年龄.如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代.

-XX:+UseParallelOldGC:配置年老代垃圾收集方式为并行收集.

整个堆大小 = 年轻代大小 + 老年代大小 + 持久代大小。

二、收集器设置

-XX:+UseSerialGC:设置串行收集器

-XX:+UseParallelGC:设置并行收集器

-XX:+UseParalledlOldGC:设置并行年老代收集器

-XX:+UseConcMarkSweepGC:设置并发收集器

三、垃圾回收统计信息

-XX:+PrintGC

-XX:+PrintGCDetails

-XX:+PrintGCTimeStamps

-Xloggc:filename

四、并行收集器设置

-XX:ParallelGCThreads=n:设置并行收集器收集时使用的CPU数.并行收集线程数.

-XX:MaxGCPauseMillis=n:设置并行收集最大暂停时间

-XX:GCTimeRatio=n:设置垃圾回收时间占程序运行时间的百分比.公式为1/(1+n)

五、并发收集器设置

-XX:+cmsIncrementalMode:设置为增量模式.适用于单CPU情况.

-XX:ParallelGCThreads=n:设置并发收集器年轻代收集方式为并行收集时,使用的CPU数.并行收集线程数.

下面举个例子:

假设有个名为TestMem.java 的文件

javac TestMem.java

java -verbose:gc -Xms20M -Xmx20M -Xmn10M -XX:+PrintGCDetails -XX:SurvivorRatio=8 TestMem

-Xms20M:JVM中Java堆的初始大小为20M。(包括新生代和老年代)

-Xmx20M:JVM中Java堆的最大大小为20M,也就是说不可扩展。(包括新生代和老年代)

-Xmn10M:新生代的大小为10M

-XX:+PrintGCDetails:打印详细GC信息

-XX:SurvivorRatio=8:新生代中一个Enden与一个Survivor区的空间比例是8:1,则两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10

知道上面的的flag信息之后,我们可以得到以下信息:

java堆的总大小为20M = 20 * 1024K = 20480K

新生代的大小:10M = 10 * 1024K = 10240K

eden space:10240K * 8/10 = 8192K

from space:10240K * 1/10 = 1024K

to space:10240K * 1/10 = 1024K

老年代的大小:20M - 10M = 10M = 10240K

总结

以上就是本文关于JVM中的flag设置详解的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序实现YDUI的ScrollTab组件
下一篇:Java编程实现获取mp3时长及播放mp3文件的方法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~