JVM垃圾回收(GC)

判断哪些对象是垃圾

  • 引用计数器算法(最早使用的算法)

    当我们在内存中创建一个对象时,会为他添加一个引用计数器,同时将引用计数器加1,当有新的引用器引用到子对象时,引用计数器再加1,当其中的一个引用销毁时,引用计数器减1,当引用计数器减为0 时,标志着此对象为垃圾对象,可被回收。

    存在问题:

    如图,当对象A引用对象B时,对象B的计数器加1,对象B再引用对象A,对象A的计数器也加1,但是并没有其他路径指向他们,此时的对象A和对象B已经成为垃圾对象,但由于二者的计数器都不为0,引用计数算法无法回收他们的内存。为了解决这个问题,可达性算法诞生了。

  • 可达性算法(根搜索算法)

    通过一系列的称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索所走过的路径称为引用链(Reference Chain),当一个对象到GC Roots没有任何引用链相连(用图论的话来说,就是从GC Roots到这个对象不可达)时,则证明此对象是不可用的,即为垃圾对象

    此处的obj4、obj6、obj7、obj8都为不可达对象,即垃圾对象

引用的类型

  • 强引用

    Object obj = new Object();
    
  • 弱引用(不会阻碍内存的回收)

    需要被 WeakReference 类包装

    WeakReference<Object> wf = new WeakReference<Object>(obj);
    
  • 软引用

    需要被 SoftReference 类 包装

  • 虚引用

    需要被 PhantomReference 类 包装

最常用到的是强引用和弱引用

垃圾回收算法

  • 标记-清除算法

如图,从根节点引用A,A引用C,则B为不可达点,进行扫描,进入标记阶段,标记B,此时B为垃圾对象,接下来进入清除阶段,扫描整个空间并清除未标记的对象

缺点就是容易产生内存碎片,碎片太多可能会导致后续过程中需要为大对象分配空间时无法找到足够的空间而提前触发新的一次垃圾收集动作。

  • 复制算法

如图,从根节点引用A,将A放置在另一块空闲的内存中,B为不可达点,跳过,A引用C,将A放置在另一块空闲的内存中,当遍历完成后,将原来的内存清空,只保留了新的内存。

优点:对象少时,效率极高

缺点:需要一块内存

  • 标记-整理算法

如图,进行全局扫描,标记出可回收的对象,进入清除阶段,将可回收对象清除,将所有的存活对象向左端空闲处移动并更新对应空闲指针

触发回收

  1. Java虚拟机无法再为新的对象分配内存空间
  2. 手动调用System.gc()方法(强烈不推荐)
  3. 低优先级的GC线程,被运行时就会执行GC
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供...
    简欲明心阅读 88,693评论 17 311
  • GC中的垃圾特指于内存中不会再使用的对象,垃圾回收有很多算法:引用计数法标记压缩法复制算法分代,分区的思想 引用计...
    MicoCube阅读 349评论 0 1
  • 作者:一字马胡 转载标志 【2017-11-12】 更新日志 日期更新内容备注 2017-11-12新建文章初版 ...
    beneke阅读 2,165评论 0 7
  • 一. 垃圾回收的意义 在C++中,对象所占的内存在程序结束运行之前一直被占用,在明确释放之前不能分配给其它对...
    Stan_Z阅读 1,850评论 0 25
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 5,879评论 2 31