jstat查看gc情况

jstat通常用来分析系统的垃圾回收情况。

1)命令:

jstat -gccause pid 2000     #每格2秒输出结果

jstat -gcutil pid  2000

jstat查看gc情况_第1张图片

2)分析:

  • S0S1 代表两个Survivor区;
  • E 代表 Eden 区;
  • OOld)代表老年代;
  • PPermanent)代表永久代;
  • YGCYoung GC)代表Minor GC
  • YGCT代表Minor GC耗时;
  • FGCFull GC)代表Full GC耗时;
  • GCT代表Minor & Full GC共计耗时。

Java 堆分为新生代和老年代,新生代一般划分为三块区域,Eden + From Survivor + To SurvivorEden Survivor 的内存比为8:1,每次只使用一个Eden 和一个 Survivor 区域,另一个Survivor 用于复制收集算法回收内存。


对象一般尽量分配到新生代中,而对于大对象(长字符串和大数组)直接分配在老年代中,同时“年龄”长的的对象会从新生代自动晋升到老年代中。

 

Java 方法区称为永久代,只有 HotSpot 虚拟机才存在永久代。

 

首先想eden区申请分配空间,如果空间够,就直接进行分配,否则进行一次Minor GCminor GC 首先会对Eden区的对象进行标记,标记出来存活的对象。然后把存活的对象copyFrom空间。如果From空间足够,则回收eden区可回收的对象。如果from内存空间不够,则把From空间存活的对象复制到To区,如果TO区的内存空间也不够的话,则把To区存活的对象复制到老年代。如果老年代空间也不够(或者达到触发老年年垃圾回收条件的话)则触发一次full GC


你可能感兴趣的:(java)