JVM之GC

如何判断对象已死?

可达性分析算法:
从一系列称为GC Roots的对象作为起点向下搜索,走过的路称为引用链。当GC Roots到某个对象不可达时,会被判定为可回收对象。
在Java中,可以作为GC Roots的对象包括以下几种:
1.虚拟机栈(栈帧中的本地变量表)中引用的对象。
2.方法区中静态属性引用的对象。
3.方法区中常量引用的对象。
4.本地方法栈中Native方法引用的对象。

一次拯救对象的机会——finalize方法

在finalize()中与任何一个对象建立关联,即可逃脱GC,但是finalize()只执行一次,下次会直接回收。

垃圾收集算法

1.标记-清除算法(Mark-Sweep)
首先标记出要被回收的对象,在标记完成后统一回收所有的被标记对象。
缺点:效率问题和空间问题。标记清除后会产生大量的不连续内存碎片,内存碎片较多可能会导致分配大对象时没有足够的连续空间而不得不触发另一次GC。
2.复制算法(Copying)
将内存划分为相同大小的两块,每次只使用其中一块,当这块内存用完了,就把还存活的对象复制到另一块内存上,把已使用过的内存空间一次性清理掉。
优点:每次只对其中一块进行GC,不用考虑内存碎片问题,实现简单,运行高效。
缺点:内存只用了一半。
3.标记-整理算法(Mark-Compact)
让所有存活对象都向一端移动,然后直接清理掉端边界以外的所有内存。

stop-the-world

在学习GC之前,你首先应该记住一个单词:“stop-the-world”。Stop-the-world会在任何一种GC算法中发生。Stop-the-world意味着 JVM 因为要执行GC而停止了应用程序的执行。当Stop-the-world发生时,除了GC所需的线程以外,所有线程都处于等待状态,直到GC任务完成。GC优化很多时候就是指减少Stop-the-world发生的时间。

bump-the-pointer 和 TLABs(Thread-Local Allocation Buffers)

Bump-the-pointer技术跟踪在伊甸园空间创建的最后一个对象。这个对象会被放在伊甸园空间的顶部。如果之后再需要创建对象,只需要检查伊甸园空间是否有足够的剩余空间。如果有足够的空间,对象就会被创建在伊甸园空间,并且被放置在顶部。这样以来,每次创建新的对象时,只需要检查最后被创建的对象。这将极大地加快内存分配速度。但是,如果我们在多线程的情况下,事情将截然不同。如果想要以线程安全的方式以多线程在伊甸园空间存储对象,不可避免的需要加锁,而这将极大地的影响性能。
TLABs 是HotSpot虚拟机针对这一问题的解决方案。该方案为每一个线程在eden空间分配一块独享的空间,这样每个线程只访问他们自己的TLAB空间,再与bump-the-pointer技术结合可以在不加锁的情况下分配内存。

垃圾收集器

image.png

Serial收集器

Serial收集器是历史最悠久的收集器。
它是一个采用复制算法的单线程收集器,单线程的意义在于,它在进行GC时会暂停其他所有的工作线程。这对很多应用来说是无法接受的。
虽然Serial收集器有各种问题,但是它依然是Client模式下默认的新生代收集器。

ParNew收集器

Serial的多线程版本,使用多条线程进行垃圾收集,其他和Serial相同。
ParNew的重要意义在于,当老年代采用CMS收集器时,新生代只能用ParNew。

Parallel Scavenge收集器

Parallel也是一个新生代收集器,它与别的收集器的区别在于,它关注的是吞吐量。吞吐量 = 运行用户代码时间 / (运行用户代码时间 + 垃圾收集时间)
几个重要参数:
-XX:MaxGCPauseMillis 最大垃圾收集停顿时间(不是时间越小越好,减少停顿时间的同时会缩小新生代大小,吞吐量降低,得不偿失)
-XX:GCTimeRadio 设置吞吐量大小(吞吐量的倒数,默认值为99,即允许最大1%的GC停顿)
-XX:+UseAdaptiveSizePolicy GC自适应调节策略 (开启后无需手工指定新生代大小、新生代和老年代比例等参数,只需要指定-Xmx最大堆内存,其他交给JVM自己调节)。
Parallel 无法和CMS收集器配合工作。

Serial Old收集器

Serial的老年代版本,采用标记——整理算法,也是一个单线程收集器。

Parallel Old收集器

Parallel 的老年代版本,采用多线程和标记——整理算法。
新生代用Parallel ,老年代用Parallel Old,吞吐量优先的策略就名副其实了。

CMS(Concurrent Mark Sweep)收集器

CMS收集器是一种以获取最短时间停顿为目标的收集器,基于标记——清除算法。
整个过程分为四个步骤,初始标记===》并发标记===》重新标记===》并发清除。其中初始标记和重新标记仍需要STW。并发标记和并发清除可以和用户线程同时工作。
CMS是一款优秀的收集器,但是仍然有3个明显缺点:
1.对CPU资源非常敏感。
2.无法处理浮动垃圾。浮动垃圾指的是在垃圾收集过程中新产生的垃圾,只能等到下次GC时回收。所以使用CMS时要预留一部分空间用作并发收集。在JDK1.6中这个阈值是92%。如果预留空间无法满足,则启动Serial Old收集器,这样的话停顿时间会很长。
3.标记——清除算法,会产生大量的空间碎片,在一段时间后不得不进行一次带压缩的Full GC。这个时间会比较长。

G1收集器

面向服务端的垃圾收集器
特点:并行与并发:缩短Stop the World停顿时间
分代收集:采用不同方式处理新对象和存活一段时间的对象
空间整合:与CMS的标记---清理算法不同,整体基于标记---整理算法,从局部(两个Region之间)基于复制算法。不会产生空间碎片。
可预测的停顿
初始标记===》并发标记===》最终标记===》筛选回收

内存分配与回收策略

1.对象优先在Eden分配。
2.大对象直接进入老年代。
3.长期存活的对象将进入老年代。
如果对象在Eden中创建且进过第一次Minor GC 后仍然存活,并且能被survivor容纳的话,将被移动到survivor空间中,年龄增加1。对象在Survivor中每熬过一次minor GC,年龄增加1岁,增加到一定程度(默认15岁),将会晋升到老年代中。
4.动态对象年龄判定。
5.空间分配担保。

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

推荐阅读更多精彩内容

  • 这篇文章是我之前翻阅了不少的书籍以及从网络上收集的一些资料的整理,因此不免有一些不准确的地方,同时不同JDK版本的...
    高广超阅读 15,595评论 3 83
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 5,961评论 2 31
  • 1.判断垃圾是否可以回收1)引用计数算法为对象添加一个计数器,有一个地方被引用了计数器就加1,失效就减1,等于0则...
    何甜甜在吗阅读 535评论 0 0
  • JVM架构 当一个程序启动之前,它的class会被类装载器装入方法区(Permanent区),执行引擎读取方法区的...
    cocohaifang阅读 1,664评论 0 7
  • A区关键词:健康/家人/亲子教育/自我提升:演讲、写作/社会关系 目标:健康、家人、自我提升:新媒体学习、写作,社...
    勇敢的每一天阅读 97评论 0 1