JVM最大能使用的内存的问题

http://blog.csdn.net/youthon/...

这篇文章说Linux上,系统进程内存最大限制,32位和64位理论上最大都可达到4G

而另外的文章说,这个最大限制可以测试,用类似于下面命令:

 java -Xmx503446m -version
 

如果不报错,说明能分配500G左右
我试了一下,

$ java -Xmx603446m -version 
Java HotSpot(TM) 64-Bit Server VM warning: INFO:         
os::commit_memory(0x00007e6915650000, 19773718528, 0) failed; 
error='Cannot allocate memory' (errno=12)
#
# There is insufficient memory for the Java Runtime Environment 
to continue.
# Native memory allocation (mmap) failed to map 19773718528 
bytes for committing reserved memory.
$ java -Xmx503446m -version 
java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)

可见500G左右没问题,600G就不行了

但是这个远超4G了啊,如何理解?

阅读 5.2k
1 个回答

4G,仅是32位操作系统的限制, 64位不受此限制, 理论上是264.

但最终都要受物理内存的限制.超出物理内存肯定是不行的.

可配置参数不代表真的可以分配内存, 新jvm允许分配多至512倍的物理/虚拟内存.

java -Xmx100000g Demo

在我的机器上跑得起来, 但实际是没有用的. 真分配的时候还是会 OutOffMemory

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题