垃圾收集器与内存分配策略

一、判断对象回收
1、判断方法
引用计数算法:对象每次引用,引用计数加1,取消引用减一,当引用计数为0,则判断对象可回收,但是难以处理两个对象的互相引用的问题。
可达性分析算法:通过一系列的称为GC Roots的对象作为起点,从这些节点往下搜索,搜索所走过的路径称为引用链,当一个对象到达GC Roots没有任何引用链相连,则此对象不可用。
可作为GC Root的对象有如下几种:
 1、虚拟机栈中引用的对象。
  2、方法区中类静态属性引用的对象。
 3、方法区中常量引用的对象。

2、Java引用分类
 强引用:只要强引用还在,垃圾收集器永远不会回收掉引用对象。
 软引用:内存发生溢出之前,会把这些对象回收。
 弱引用:不管内存是否足够,垃圾收集器工作时,会回收掉这些对象。
 虚引用:无法通过虚引用获取对象实例。
3、生存还是死亡
  可达性分析算法中不可达的对象,也并非非死不可,它们暂时处于缓刑阶段,真正的死亡,还是要经过两次标记筛选,第一次,筛选的标准,对象是否有必要执行finalize方法,当对象没有覆盖finalize方法,或者已经执行过,则执行对象回收,对象被判定有必要执行finalize方法,则会把对象放入队列中,虚拟机机则会在开启低优先机线程去执行它,稍后GC将对队列中对象进行第二次标记。
4、方法区(永久带)的垃圾回收
   方法区进行垃圾回收性价比比较低,回收主要分为两部分:废弃的常量和无用的类。

二、垃圾回收算法
 标记清除算法
分为标记和清除两个阶段,缺点:标记和清除的效率都不高;另一个就是空间问题,标记清除后产生大量的内存碎片,内存碎片可能导致,下次分配较大对象时,无法获取到足够大的内存地址,而出发GC操作。
复制算法
将内存分为大小相等的两块,每次使用一块,当这块使用完了,就将活着的对象复制到另一块,然后一次清除掉使用的那块,这种方式不存在内存碎片的问题,但是内存的使用效率却降低了。新生代垃圾回收才用次回收算法,Eden和两块Survivor区间分配比例:8:1:1,每次使用Eden和其中一块Survivor,当回收时,将Eden和Survivor中活着的对象复制到另一块Survivor中,如果另一块Survivor大小不够,这些对象通过分配担保进入老年代。
 标记整理算法
 将标记好的对象,当回收时,所有存活的对象往一端移动,清除掉所有端边界以外的空间。
 分代收集算法
  把Java堆分为新生代和老年代,新生代每次垃圾收集时有大批的对象死去,存活很少,选用复制算法,老年代对象存活率高又不能进行分配担保,使用标记清除或者标记整理。
         当垃圾回收时,所有的线程到达安全点,GC开始垃圾回收,通过抢断式中断和主动式中断来保证到达安全点。抢断式中断:中断所有的线程,如果线程不在安全点,就恢复线程,到达安全点;主动式中断,设置一个标志,所有的线程都去轮训这个标志,当标志为真时,线程主动挂起中断。
安全区域:指一段代码片段中,引用关系不会发生变化,在这个区域,任何地方开始GC都是安全的,线程执行到安全区域,首先标识自己进入安全区域,发生GC时,就不用管标识安全区域的线程了。

二、垃圾收集器
 Serial:单线程收集器,工作时,停止所有的用户工作线程。停顿时间长。
 ParNew:Serial收集器的多线程版本,其他的和Serial一样。
Parallel Scavenge:新生代收集器,并行多线程,特点达到一个可控制的吞吐量,吞吐量=代码的运行时间/(代码运行时间+垃圾收集的时间)

Serial Old:老年代,单线程收集器,可与ParNew Serial和 Serial 和 Parallel Scavenge 搭配使用。
  采用标记整理算法。
Parallel Old:老年代,是Parallel Scavenge收集器的老年代收集器,多线程。
CMS收集器:以获取最短停顿时间为目标的收集器,重试服务的响应速度,希望服务停顿的时间更短,可以考虑此收集器,CMS收集器采用标记清除算法,优点:并发收集,并发清除。
缺点:CMS默认启动的线程数是(CPU数量+3)/4,当CPU数量大于4时,并发回收时垃圾收集线程不少于25%的CPU资源,随着CPU数量增加而下降,当CPU少于2个的时候,CMS对用户线程的影响很大。
  CMS无法收集处理浮动垃圾,可能导致失败而导致另一次Full GC的产生,并发的过程又会不断产生新的垃圾。
 CMS标记清除:会产生大量的碎片,导致空间浪费。

初始标记:只标记GCRoots能直接关联到的对象,速度很快。
并发标记:就是进行GCRoots Tracing的过程。
重新标记:为了修正并发标记期间因用户程序继续运作而导致标记变动的那一部分对象的标记记录。
并发清除:可以和用户线程一起并发执行。
G!:收集器,并发并行,分代收集,空间整合,标记-整理,可预测的停顿。

二、内存分配与回收策略
 1、对象优先在Eden分配:当Eden没有足够的空间时,进行一次GC,如果还没够分配,则通过分配担保进入老年代。
2、大对象直接进入老年代:大对象是指那些需要大量连续内存空间的Java对象,比如那些很长的字符串和数组。
3、长期存活的对象进入老年代:
4、动态年龄判定:如果在Survivor空间中相同年龄的所有对象大小的和大于Survivor总空间的一半,年龄大于或者等于该年龄的对象直接进入老年代。
5、分配担保:



 

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

推荐阅读更多精彩内容