为什么在JVM中MaxNewSize比MaxHeapSize大?
为什么在JVM中MaxNewSize比MaxHeapSize大?,jvm,Jvm,我只在启动时设置一些JVM配置:-Xmx1024m-Xms1024m-XX:MaxPermSize=128m-XX:PermSize=128m年轻一代到老一代的大小由NewRatio控制。因此,即使MaxNewSize>MaxHeapSize,当NewRatio=2时,新空间的有效最大大小为1:2。老一代占堆的2/3,新一代占堆的1/3 在您的例子中,旧空间为2/3*1024=682.6M,新空间为1/3*1024=341M MaxNewSize的阈值只有在低于NewRatio提供的阈值时才会生
我只在启动时设置一些JVM配置:
-Xmx1024m-Xms1024m-XX:MaxPermSize=128m-XX:PermSize=128m
年轻一代到老一代的大小由NewRatio控制。因此,即使MaxNewSize>MaxHeapSize,当NewRatio=2时,新空间的有效最大大小为1:2。老一代占堆的2/3,新一代占堆的1/3
在您的例子中,旧空间为2/3*1024=682.6M,新空间为1/3*1024=341M
MaxNewSize的阈值只有在低于NewRatio提供的阈值时才会生效。可以将这些视为配置内存的多个独立旋钮。JVM将选择符合所有设置的设置。来自:
由于您没有明确设置MaxNewSize
,因此采用了经过特殊处理的默认值。无论如何,
MaxNewSize
值只是一个提示,而NewSize
保留了年轻一代的实际规模
product(uintx, MaxNewSize, max_uintx, \
"Maximum new generation size (in bytes), max_uintx means set " \
"ergonomically") \