本文介绍: 书接上文上个博文由于再次发布,可能之前看过的小伙伴不知道我又有更新,所以单独提了出来;这里面也有些问题,恰好可以给各位大神看下,有能给指点一二的,不胜感激;根据设置jvm参数,查看参数是否生效,堆中内存分配是否符合预期虽然与预期的大小总是相差一点,但是相对来说,调整jvm参数已经初窥门径了;如有能指点的大神,希望不吝赐教~


前言

书接上文上个博文
由于再次发布,可能之前看过的小伙伴不知道我又有更新,所以单独提了出来;
这里面也有些问题,恰好可以给各位大神看下,有能给指点一二的,不胜感激;
根据设置的jvm参数,查看参数是否生效,堆中内存分配是否符合预期


一、启动java项目

设置jvm参数
设置参数
启动后,找到jdkbin路径,调用cmd,执行命令

二、开始验证

设置项目的jvm参数

命令

1 查看java进程 jps
jps

2 设置jvm参数 -Xms512m -Xmx512m
设置jvm参数
3 查看当前进程的具体内存分配 jmapheap 22096
内存分配
堆的总大小为512m
NewRatio 新生代与老年代的比例为1:2 则: 新生代为 170m 老年代为 340m
由于eden: s0 : s1 等于 8:1:1 所以 s0=s1 大概等于17m左右,剩余为eden区域大小 大概为134m左右
哎…但是出现的结果不一致 s0 =s1 大概为 21m eden区域大概为 129m

有大神知道为啥嘛? 与正常结果差4

-Xms1024m -Xmx1024m -XX:NewSize=500m

设置jvm参数

1 在不考虑新生代大小的情况下,正常来说结果应为 eden: s0 : s1 为271:34:34 与正常结果s0差 8
2 由于设置了新生代大小,所有新生代为固定大小 500m
3 那么 eden: s0 : s1 仍为8:1:1,所以大小应该为 400:50:50
4 由于与结果相差8 ,所以大概应该为386:58:58
上图验证结果

结果

我真的是,无法把握它的准确大小了


总结

虽然与预期的大小总是相差一点,但是相对来说,调整jvm参数已经初窥门径了;
如有能指点的大神,希望不吝赐教~

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注