GC机制

判断对象是否存活

  • 引用计数算法
    定义: 给对象中添加一个引用计数器,每当有地方对其进行引用,计数器数值加1,当引用失效时,计数器就减1,任何时刻计数器为0的对象就是不可能再被使用的。

但是Java虚拟机中并没有使用计数算法来管理内存,因为它很难解决对象之间相互循环引用的问题。如下代码中这种相互引用,导致引用计数一直不为0

public class  RefrenceGC(){
     public Object instance = null;
     public static void testGC(){
          RefrenceGC objA = new RefrenceGC();
          RefrenceGC objB = new RefrenceGC();
          objA.instance = objB;
          objB.instance = objA;

          objA = null;
          objB = null;
     }
}

  • 可达性分析算法
    在主流的商用程序语言(Java,C#,Lisp)的主流实现中,都是称通过可达性分析来判定对象是否存活。
    思路: 通过一系列称为“GC Roots”的对象作为起始点,从这些节点开始向下搜索,搜索走过的路径称为引用链(Reference Chain),当一个对象到GC Roots没有任何引用链相连时(用图论的话来说,就是从GC Roots到这个对象不可达),则证明此对象是不可用的。
可达性分析算法.png

图中对象object5,object6,object7虽然相互有关联,但是它们到GC Roots是不可达的,因为它们将会被判定为可回收对象。

生存还是死亡
即使在可达性分析后的不可达对象,也不是“非死不可”,如果要真正宣告死亡,至少经历两次标记过程:如果对象在进行可达性分析后发现没有与GC Roots相连接的引用链,就会被第一次进行标记并且进行一次删选,判断是否有必要执行finalize()方法,当对象没有覆盖finalize()方法,或者finalize()方法已经被虚拟机调用过,即会被判为没有必要执行。
如果被判定为有必要执行的finalize()方法,对象将会被放置在F-Queue的队列中,会有个低优先级的Finalizer线程去执行,finalize()方法是对象逃脱死亡命运的最后一次机会,如果要拯救自己,就需要重新与引用链上的任意一个对象建立起关联即可。

垃圾收集算法

标记-清除算法

对需要回收的进行标记,然后清除标记对象。
缺点:
1、效率低,标记和清除两个过程的效率都不高
2、空间问题,标记清除后产生大量不连续的内存碎片,在下次分配较大的对象时,无法找到足够的连续内存而不得不提前触发另一次垃圾回收。

标记清除.png

复制算法

将内存按照等容量分为两块,每次只使用其中一块,一块用完,将还存活的复制到另一块上,然后进行整块清除。
缺点:内存缩为原来的一半

商业化虚拟机采用此种方式,不按标准的1:1划分,而是划分一块大的Eden 和两块小的Survivor空间,每次使用Eden和一块小的Survivor,使用完,将存活的复制到另一块小的Survivor上,然后清除Eden和那块Survivor。默认Eden 和Survivor比为8:1。

标记-整理算法

标记后,让所有存活的往一端移动,直接清理端边界外面的内存

标记整理.png

分代收集算法
一般划分为新生代和老年代,新生代少量对象存活,采用复制算法,老年代对象存活率高,采用标记-清除或者标记-整理方法去处理。

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

推荐阅读更多精彩内容

  • 最近学习Python的GC机制时,想到了java的GC,忘得差不多了,(⊙﹏⊙)b!!这里便做一下回顾总结。推荐周...
    廿陆小生阅读 845评论 0 0
  • 一、什么是GC 在Java中,对象所占用的内存在对象不再使用后会自动被回收。这些工作是由一个叫垃圾回收器 Garb...
    Elder阅读 5,006评论 0 1
  • 一、前言 JAVA GC(Garbage Collection,垃圾回收)机制是区别C++的一个重要特征,C...
    EnjoyAndroid阅读 1,412评论 0 3
  • 原文阅读 前言 这段时间懈怠了,罪过! 最近看到有同事也开始用上了微信公众号写博客了,挺好的~给他们点赞,这博客我...
    码农戏码阅读 5,958评论 2 31
  • 1.我们知道在Php中准备语句的执行有execute(array())的方式,还有bindParam()的方式,但...
    Jacqueline_JS阅读 1,347评论 1 0