深入理解JAVA虚拟机学习笔记6——七种垃圾收集器介绍和对比

本来这一篇应该是和大家分享以下HotSpot的算法实现的,但是有部分内容存在一些疑问,还需进一步研究一下,今天就简单介绍一下几种不同的垃圾收集器。

开始之前有几点需要提前介绍一下。

第一点,书中提到了一个词,“Stop The World”——即当进行垃圾收集的时候,必须暂停其它所有的工作线程。

第二点,Java的HotSpot虚拟机有两种工作模式,Client模式(轻量级)和Server模式(重量级)。

可以通过在cmd中输入命令java -version进行查看。

第三点,这个要注意啦!!!在讨论垃圾收集器的时候,并发和并行的概念。

并发:传统意义上并发是只一个时间段内多个线程或进程同时执行(时间片轮流调度),但是时间点上只有一个在执行。

在这里,指用户线程和垃圾收集线程同时执行,分别在不同的CPU中。

并行:传统意义上并行是不光一个时间段内多个线程或进程同时执行,时间点上也有多个线程或进程在执行(多核CPU)。

在这里,指的是多条垃圾收集线程并行工作,但用户线程处于暂停状态。

知道了这几个概念之后,下面简单介绍一下这七种垃圾收集器。

1 Serial收集器:最基本,发展历史最久远的收集器。

采用单线程的工作方式,会“Stop The World”,适用于Client模式下虚拟机。

优点:和其它单线程的相比,不存在并发,没有线程切换的开销,简单而高效。

2 ParNew收集器:Serial的多线程版本,使用多线程并行进行垃圾收集,并且是并发的,不存在“Stop The World”;适用于Client模式下虚拟机。

3 Parallel Scavenge收集器:也是并行多线程的,与其它的收集器的不用之处在于,Parallel Scavenge收集器关注的是控制吞吐量。可以通过调整参数,控制停顿时间或最大的吞吐量(自适应调节策略)。

吞吐量=运行用户代码时间/(运行用户代码时间+垃圾收集时间)

提高吞吐量可以提高CPU的利用率,适合在后台运算而不需要太多交互的任务(什么鬼)?

4 Serial Old收集器:Serial收集器的老年代版本,也是单线程的。

5 Parallel Old收集器:Parallel Scavenge收集器的老年代版本。

6 CMS(Concurrent Mark-Sweep)收集器:为了满足B/S项目响应速度的要求,以获取最短回收停顿时间为目标;可并发收集但是仍然会出现“Stop The World”。

7 G1收集器:当前收集器技术发展最前沿的技术之一;面向服务端应用;

特点:并行+并发;分代收集;空间整合;可预测的停顿;

具体的详情可以对照下表。

另附各收集器之间的组合使用图(图片参照《深入理解JAVA虚拟机》)

GC日志:这里只要记住日志内容每一项代表的规则就可以了。

举个例子,使用IDEA编写如下代码

以前介绍过如何设置idea的JVM参数,这里直接在debug中进行配置,增加打印详细日志参数-XX:+PrintGCDetails

点击debug运行程序,控制台打印如下内容。下面让我们一次进行分析。

1. GC日志开头的“[GC”和“[Full GC”说明了这次垃圾收集的停顿类型,如果有”Full”,说明这次GC发生了”Stop-The-World”;

2. 紧跟着括号内的“System.gc()”表示本次回收的触发方式;

3. 接下来的“[PSYoungGen”,“[ParOldGen”,“[Metaspace”表示GC发生的区域;

4. 方括号里面的“6856K->0K(76288K)”,“8K->6717K(175104K)”等表示的是“GC前该内存区域已使用的容量->GC后该内存区域已使用的容量(该内存区域总容量)”;

5. 方括号外面的“6864K->6717K(251392K)”表示“GC前Java堆已使用容量->GC后Java堆已使用容量(Java堆总容量)”;

6. 再往后的“0.0054064 secs”表示的是内存区域GC所占用的时间,单位是秒;

7. 最后面的“[Times: user=0.06 sys=0.00, real=0.01 secs]”是更具体的时间,分别代表用户态消耗的CPU时间,内核态消耗的CPU时间,操作从开始到结束所用的时钟时间;

8. 书中介绍开头时候还会有如“33.125:”样式的GC发生时间,记录的是从Java虚拟机启动以来经过的秒数,笔者使用的JDK8是没有显示的。

喜欢文章或想一起学习的朋友可以关注我,我将会持续更新,有什么疑问或文中有不当之处请给我留言,真诚地希望能与大家一起交流探讨,学习进步。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容