JVM默認老年代回收是 PSMarkSweep(Serial-Old) 還是Parallel Old?


這個問題的答案取決於JDK版本,在2012年默認值改變過一次。

請參考:JDK-6679764: enable parallel compaction by default
這個改進使得HotSpot VM在選擇使用ParallelGC(-XX:+UseParallelGC 或者是ergonomics自動選擇)的時候,會默認開啟 -XX:+UseParallelOldGC 。這個變更應該是在JDK7u4開始的JDK7u系列與JDK8系列開始生效。

對應的patch是:
jdk8u/jdk8u/hotspot: 24cae3e4cbaa
--- a/src/share/vm/runtime/arguments.cpp Mon Jan 30 15:21:57 2012 +0100 +++ b/src/share/vm/runtime/arguments.cpp Thu Feb 02 16:05:17 2012 -0800 @@ -1400,10 +1400,11 @@  void Arguments::set_parallel_gc_flags() { assert(UseParallelGC || UseParallelOldGC, "Error"); - // If parallel old was requested, automatically enable parallel scavenge. - if (UseParallelOldGC && !UseParallelGC && FLAG_IS_DEFAULT(UseParallelGC)) { - FLAG_SET_DEFAULT(UseParallelGC, true); + // Enable ParallelOld unless it was explicitly disabled (cmd line or rc file). + if (FLAG_IS_DEFAULT(UseParallelOldGC)) { + FLAG_SET_DEFAULT(UseParallelOldGC, true);  } + FLAG_SET_DEFAULT(UseParallelGC, true);  // If no heap maximum was requested explicitly, use some reasonable fraction // of the physical memory, up to a maximum of 1GB. 

在這個改變之前,即便選擇了ParallelGC,默認情況下ParallelOldGC並不會隨即開啟,而是要自己通過 -XX:+UseParallelOldGC 去選定。

在GC日志里,如果看到Full GC里有"ParOldGen"就是選擇了ParallelOldGC。
[Full GC [PSYoungGen: 480K->0K(3584K)] [ParOldGen: 4660K->4909K(12288K)] 5141K->4909K(15872K) [PSPermGen: 11202K->11198K(22528K)], 0.0515530 secs] [Times: user=0.08 sys=0.00, real=0.05 secs]
 
鏈接:https://www.zhihu.com/question/56344485/answer/149543993
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM