一、查看步骤

cmd执行命令:

java -XX:+PrintCommandLineFlags -version

输出如下(举例):

ae4340c501615ca3e3d39c182ff2c12a.png

针对上述的-XX:UseParallelGC,这边我们引用《深入理解Java虚拟机:JVM高级特性与最佳实践》的介绍:

0613b674eceb367b3e466b4c2869c2b7.png

也就是说,打开此开关,使用的垃圾收集器是:新生代(Parallel Scavenge),老年代(Ps MarkSweep)组合。

二、验证下,是不是那么回事吧

我用ide起了一个程序,然后在main中进行长时间睡眠。启动时,设置其VM 参数如下:

75eeb6f1d950a2060bfe986ece2ee063.png

然后用Jconsole连接该程序,切换到VM概要这个tab,注意下图红圈圈出来的地方:

54ec8f69e266d3ab53d550b06cf5db6a.png

结合第一步中的资料,很容易验证,使用-XX:UseParallelGC的情况下,使用的垃圾收集器为:新生代(Ps Scanvenge),老年代(Ps MarkSweep,与Serial Old)。

三、Ps Scanvenge的简要介绍

9ea15f3d34b400c13577fd6a4f8a99a0.png

b65e813c1b0d340f57d779c629501aa2.png

3a9c278c89581d6c435d681f39cd7d15.png

这边附上我的简单理解:该垃圾收集器适用于新生代,采用标记复制算法、多线程模型进行垃圾收集。

与其他新生代垃圾收集器的差别是,它更关注于吞吐量,而不是停顿时间。一般来说,需要与用户交互的

程序更关注较短的停顿时间,而如果是需要达成尽量大的吞吐量的话,则该处理器会更加适合。

其通过-XX:UseAdaptiveSizePolicy参数,可以开启其自动调节功能,适用于对垃圾收集器的调优不太了解的

用户。

四、Serial Old的简要介绍

429e65559bf8d12532f18883bceba61d.png

我的理解:和其他老年代垃圾处理器一样,都是使用的标记整理算法,(毕竟没有靠山可以担保,没法复制,只能自己整理了,哎),

采用单线程处理模型。

五、Serial Old和Ps MarkSweep的区别

edc646bef9835a132a8b9a281484613a.png

如上图所示,也说了,在实际中,(正如第二节的截图所示),实际应用中,大多使用的就是Ps MarkSweep。

Ps MarkSweep是以Serial Old为模板设计的,按照我们程序员的说法,估计是拷贝过来,改吧改吧出来的。

所以差不太多。

原文:https://www.cnblogs.com/grey-wolf/p/9217497.html

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐