一、串行
- JDK1.5前的默认算法
- 缺点是只有一个线程,执行垃圾回收时程序停止的时间比较长
- 语法
- -XX:+UseSerialGC
- 新生代、老年代使用串行回收
- 新生代复制算法
- 老年代标记-压缩
- 示例图
- 测试代码
//-Xmx20m -Xms20m -Xmn2m -XX:+UseSerialGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps
byte[] b = null;
for (int i = 0; i < 7; i++)
{
b = new byte[3 * 1024 * 1024];
}
串行的关键字是DefNew(年轻代)、Tenured(年老代)、Perm(永久代)
0.162: [GC0.162: [DefNew: 1562K->191K(1856K), 0.0030044 secs]
0.165: [Tenured: 15917K->3820K(18432K), 0.0059132 secs] 16922K->3820K(20288K),
[Perm : 2890K->2890K(21248K)], 0.0090042 secs] [Times: user=0.01 sys=0.00, real=0.01 secs]
二、并行
- 多个线程执行垃圾回收
- 适合于吞吐量的系统,回收时系统会停止运行
- 语法
- -XX:+UseParNewGC(新生代使用并行收集器,老年代使用串行回收收集器)
关键字(ParNew) - -XX:+UseParallelGC(新生代使用并行回收收集器,老年代使用串行收集器)
- -XX:+UseParallelOldGC(新生代,老年代都使用并行回收收集器)
关键字(PSYoungGen) - -XX:+UseConcMarkSweepGC(新生代使用并行收集器,老年代使用CMS)
- -XX:ParallelGCThreads 限制并行线程数量
- -XX:MaxGCPauseMills GC最大停顿毫秒数
- -XX:GCTimeRatio 垃圾回收占用的CPU时间比例,默认99代表最大运行1%时间做GC
- 新生代复制算法
- 老年代标记-压缩
- 示例图
- UseParNewGC 代码同串行,年轻代并行,年老代串行
-Xmx20m -Xms20m -Xmn2m -XX:+UseParNewGC -XX:+PrintGCDetails -XX:+PrintGCTimeStamps
0.193: [GC0.193: [ParNew: 1601K->192K(1856K), 0.0093101 secs]0.202: [Tenured: 15948K->3834K(18432K), 0.0060758 secs] 16961K->3834K(20288K), [Perm : 3144K->3144K(21248K)], 0.0154452 secs] [Times: user=0.01 sys=0.00, real=0.02 secs] - UseParallelGC 功能同UseParNewGC
- UseParallelOldGC 代码同串行,年轻代、年老代都并行
0.141: [GC [PSYoungGen: 1024K->488K(1536K)] 1024K->624K(19968K), 0.0166419 secs] [Times: user=0.03 sys=0.00, real=0.02 secs]
0.212: [GC [PSYoungGen: 1012K->504K(1536K)] 16509K->16157K(19968K), 0.0019856 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
0.215: [GC [PSYoungGen: 504K->504K(1536K)] 16157K->16181K(19968K), 0.0029741 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
0.218: [Full GC [PSYoungGen: 504K->0K(1536K)] [ParOldGen: 15677K->3810K(18432K)] 16181K->3810K(19968K) [PSPermGen: 2891K->2890K(21504K)], 0.0133807 secs] [Times: user=0.01 sys=0.00, real=0.01 secs]
三、并发
- 系统和垃圾回收一起执行,系统不会暂停
- 适合于响应要求高的系统,回收时系统不会停止运行