java内存参数设置 16G,JVM: 能不能在16G机器上设置17G的堆?

这是一个很有意思的问题:假设我们现在有一台物理内存16G的机器,那么我们能否给运行于其上的Java虚拟机分配大于16G大小的堆呢?

从直觉上来说,这似乎有点不太可能。但是稍微有点操作系统知识的人就会意识到,这其实是可以的。因为当我们设置堆大小为17G的时候,其实并不是直接分配了17G的物理内存。而只是分配了17G的虚拟内存。这些虚拟内存尚没有映射到真实的物理内存上。

为了验证这个结果,做一个小实验。

public class HelloWorld {

public static void main(String[] args) {

System.out.println("Hello, world");

}

}

它会在我的Mac上运行,我的Mac物理内存16G:

很显然,我的机器已经占用了很多内存了,只剩下不多的东西。然后运行HelloWorld的main方法,设置参数:

-Xms17g -Xmx17g

将堆的大小固定为17G。

成功输出了结果:

现在我们进一步考虑这个问题,17G只是比16G大了一点点,也就是说,物理内存加上swap space,是大于17G的。如果我们将这个值设置得更加大,以至于

你可能感兴趣的:(java内存参数设置,16G)