jvm-内存分配

怎样查看堆内存?[面试7.0]

System.out.println(Runtime.getRuntime().maxMemory()/(double)1024/1024+“M”);// 最大堆内存(-Xmx)
System.out.println(Runtime.getRuntime().totalMemory()/(double)1024/1024+“M”);// 初始化堆内存(-Xms)

怎样设置堆内存?[面试7.0]

最大堆内存(-Xmx)默认为物理内存的1/4,初始化堆内存(-Xms)默认为物理内存你的1/64
最大堆内存(-Xmx)和初始化堆内存(-Xms)设置为一样的,避免在GC后调整堆大小带来的性能问题
不论是重视实时性还是重视数据吞吐量,所有jvm进程堆内存最好不要超过物理内存的3/4,因为还有一部分是非堆和硬件,以及其他操作系统进程所需要的内存
年轻代和老年代默认为1:2,推荐配置为年轻代的eden区和2个Survivor区一般分配为8:1:1
4核心8G内存配置一般情况下是如下配置:
-Xms4g #初始化堆内存
-Xmx4g #最大堆内存
-Xmn2g #年轻代
-XX:MetaspaceSize=256M #元空间
-XX:MaxMetaspaceSize=256M #最大元空间
-XX:ReservedCodeCacheSize=256M #JIT编译的代码存放区
-XX:MaxDirectMemorySize=1g #DirectByteBuffer能分配的空间的限额
8核16G内存配置一般情况下是如下配置:
-Xms10g
-Xmx10g
-Xmn6g
-XX:MetaspaceSize=512M
-XX:MaxMetaspaceSize=512M
-XX:ReservedCodeCacheSize=512M
-XX:MaxDirectMemorySize=1g

你可能感兴趣的:(Java面试宝典,java,spring,spring,boot)