一、问题
在学习深入理解Java虚拟机(第二版)的3.6内存分配与回收策略中遇到了一个问题,就是代码清单3-5,3-6,3-7在运行结束后控制台GC打印结果与书上的不同(这里就不列举我的打印结果了)。
二、问题解决与分析
后来查阅资料与博客,以及仔细查看书籍,发现打印结果和回收策略不同的根本原因在于对不同垃圾回收器的垃圾回收机制以及垃圾回收后的对象重新分配内存的机制不同(虽然所有的垃圾回收器具体细节不同,但是很多大体的策略是相同的).
1.问题的原因:
之前自己的电脑跑过tomcat,所以虚拟机就自动将垃圾回收器调整成了Server默认使用的回收器,也就是ParallelGC
所以在Client端做测试时,发现垃圾回收和内存分配的机制与书上不同。
2.解决:设置垃圾回收器
-XX:+UseSerialGC,虚拟机运行在Client模式下的默认值,Serial+Serial Old。
-XX:+UseParNewGC,ParNew+Serial Old,在JDK1.8被废弃,在JDK1.7还可以使用。
-XX:+UseConcMarkSweepGC,ParNew+CMS+Serial Old。
-XX:+UseParallelGC,虚拟机运行在Server模式下的默认值,Parallel Scavenge+Serial Old(PS Mark Sweep)。
-XX:+UseParallelOldGC,Parallel Scavenge+Parallel Old。
-XX:+UseG1GC,G1+G1。
由于我们的测试是在Client端,所以用SerialGC也就是默认的比较好,所以在程序运行之前设置JVM参数为-XX:+UseSerialGC就可以得到和书上相同的结果了