一、栈的大小缺省为1M,可用参数 –Xss调整大小,例如-Xss256k
二、虚拟机加载的类信息,方法信息,常量(例如"abc","123"等),静态变量(static变量)等数据的存储配置:
1.jdk1.7及以前存储在方法区/永久代:
-XX:PermSize=256m
-XX:MaxPermSize=512m
2.jdk1.8以后存储在元空间Metaspace(放置在堆中):
-XX:MetaspaceSize=800m
-XX:MaxMetaspaceSize=1024m
jdk1.8以后理论最大大小只受本机总内存的限制。
三、堆
堆分为新生代(Eden空间、From Survivor空间、To Survivor空间)、老年代(Tenured Generation空间)。
可以通过-XX:NewRatio、-XX:SurvivorRatio选项来配置年轻代和老年代的比例以及Survivor空间的比例。
Java垃圾回收机制只作用于堆区,对非堆区没有作用。
-Xms100m:堆的最小值
-Xmx900m:堆的最大值
-Xmn200m:新生代的大小(一种简写,代表对下面2个参数同时配置)
-XX:NewSize=300m;新生代堆空间的默认值
-XX:MaxNewSize=800m:新生代堆空间最大值
-XX:NewRatio:一个整数,表示老年代和新生代的比值。例如,若 -XX:NewRatio=3,则新生代占整个堆的1/4,老年代占3/4。
-XX:SurvivorRatio:一个整数,用于指定新生代中Eden区域与Survivor区域的比值。例如,若-XX:SurvivorRatio=8,则一个Survivor区域的大小将是Eden区域大小的1/8。
四、直接内存
直接内存不是java虚拟机规范中定义的内存区域。如果使用了NIO,那么直接内存会被使用。
直接内存是由java.nio包中的ByteBuffer.allocateDirect()方法分配的内存,这块内存不受java堆大小限制,但受本机总内存的限制,所以也会出现OOM(Out Of Memory)内存溢出异常,可以通过-XX:MaxDirectMemorySize来设置(默认与堆内存最大值一样)。
-XX:MaxDirectMemorySize=512m
五、代码缓存
代码缓存是即时编译器JIT编译的热点方法的机器码,可以提高JVM性能。
1)-XX:ReservedCodeCacheSize=400m
JVM分配给代码缓存的总大小。
2)-XX:InitialCodeCacheSize=200m
JVM分配给代码缓存的初始大小。
微风不燥,阳光正好,你就像风一样经过这里,愿你停留的片刻温暖舒心。
我是程序员小迷(致力于C、C++、Java、Kotlin、Android、Shell、JavaScript、TypeScript、Python等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。
欢迎关注。助您在编程路上越走越好!