标签:clean up 优势 oschina 绿色 tab 合并 特殊 aac static
垃圾收集器是jvm实现内存回收的具体实现。本次分享要介绍的7种垃圾收集器的作用区域及其之间的关系如下图:
注:
算法 | 内存区域 | 执行方式 |
---|---|---|
复制算法 | 新生代 | 单线程、串行 |
先暂停全部用户线程(Stop The World),然后开启一条GC线程使用复制算法对垃圾进行回收。直到收集结束被暂停的线程才能继续执行
平时的开发与调试程序使用,以及桌面应用交互程序。
算法 | 内存区域 | 执行方式 |
---|---|---|
标记/整理算法 | 老年代 | 单线程、串行 |
执行过程、特点、使用场景与Serial收集器类似
算法 | 内存区域 | 执行方式 |
---|---|---|
复制算法 | 新生代 | 多线程、并行 |
开启多个GC线程使用复制算法并行进行垃圾回收
在中到大型的堆上,且系统处理器至少多于一个的情况。
算法 | 内存区域 | 执行方式 |
---|---|---|
复制算法 | 新生代 | 并行 |
ParNew收集器基本类似,只不过优先满足最大停顿时间的目标,次之是吞吐量,最后才是新生代区域的最小值。
吞吐量=运行用户代码的时间/CPU总消耗时间
适用于与用户交互的程序,良好的响应速度能提升用户体验,高吞吐量则可以高效的利用cpu。主要适合在后台运算而不需要太多交互的任务
算法 | 内存区域 | 执行方式 |
---|---|---|
标记/整理算法 | 老年代 | 并行 |
除了serial old以外唯一一个可以与parallel scavenge搭配工作的年老代搜集器
算法 | 内存区域 | 执行方式 |
---|---|---|
标记/清除算法 | 老年代 | 多线程、并行 |
1.初始标记阶段,时间很短,只会标记直接与GC Root相连的对象 2.重新标记阶段,时间比初始化标记稍长
在进行标记阶段,标记的对象不再从GC Root可达,因此在这次GC过程中该对象内存空间不会被回收,因此造成了浮动垃圾。
这些浮动垃圾会占用一些内存,但下次GC会被回收。
在并发标记阶段,GC线程没有标记(用户线程之前没在用),在标记过程中,用户线程又重新引用了该对象。如果该对象依然被回收,那么程序就直接报错了。
下面举个例子说明,设计A是被GC Root相关联的对象,假设现在正在搜索A相关联的对象,这个时候A被标记为灰色,搜索到A引用了B,这个时候B也会被标记为灰色,如下图
当A搜索完以后,A被标记为绿色,这个时候直接与A相连的B和C已被标记为灰色,但D没有,因为D没有直接与A相连,如下图
然后继续搜索B直接引用的对象,假设这个过程中,C不再引用D,如下图
如果在搜索C相关的引用后,D依然处于不可达的状态,假设这个时候已经标记完成的对象B引用了D,如下图
如果D被回收,那么在后面的程序肯定会有问题
此时的解决办法就是有一个叫做写入屏障(注意在G1收集器中会比较)的东西。就是说,如果B已经被标记了(已经是绿色的了),那么用户线程改动 B->D的时候,会把D变成灰色,这样,以后就可以搜索D了。
由于其他垃圾回收器都是 "stop the world",那么内存不够了就执行 GC。但是 CMS 垃圾回收器是可以和用户线程一起并发的。假设在执行GC过程中内存不够了怎么办?这个时候就会有预备方案,Serial Old 垃圾回收器会替代 CMS,进行 "stop the world"垃圾收集。
使用-XX:CMSInitiatingOccupancyFraction的值来设定触发GC的内存百分比
CMS是一款基于“标记-清除”算法实现的收集器,收集结束时会有大量的空间碎片产生。当无法找到足够大的连续空间来分配当前对象,不得不提前触发一次full Gc。
默认是打开的,用户在CMS收集器顶不要进行Full GC时开启内存碎片的合并整理过程,内存整理的过程是无法并发的,空间碎片的问题没有了,但停顿的时间会变长
设置多少次不压缩Full GC后,跟着来一次带压缩的碎片整理,默认为0。
CMS收集器对CPU资源非常敏感.CMS默认启动的回收线程数是(CPU数量+3)/4,在并发阶段,它虽然不会导致用户线程停顿,但是会占用一部分线程而导致应用程序变慢,总吞吐量对降低。
重视服务的响应速度,希望系统的停顿时间最短,以带来较好的用户体验,例如互联网站或B/S系统的服务端上,
CMS垃圾收集器虽然减少了暂停应用程序的运行时间,但是它还是存在着内存碎片问题。于是,为了去除内存碎片问题,同时又保留CMS垃圾收集器低暂停时间的优点,JAVA7发布了一个新的垃圾收集器 - G1垃圾收集器。
Eden,Survivor和Tenured等内存区域不再是连续的了,而是变成了一个个大小一样的region - 每个region从1M到32M不等。一个region有可能属于Eden,Survivor或者Tenured内存区域。 在G1中,还有一种特殊的区域,叫Humongous区域。 如果一个对象占用的空间超过了分区容量50%以上,G1收集器就认为这是一个巨型对象。G1划分了一个Humongous区,它用来专门存放巨型对象。如果一个H区装不下一个巨型对象,那么G1会寻找连续的H分区来存储。为了能找到连续的H区,有时候不得不启动Full GC。
在G1垃圾收集器中CMS垃圾收集器差不多,回收Eden region和Survivor region上的非可达对象,同时升级存活的可达对象到对应的Survivor region或Tenured region上。
对于年老代上的垃圾收集,G1垃圾收集器也分为4个阶段,基本跟CMS垃圾收集器一样,但略有不同:
标签:clean up 优势 oschina 绿色 tab 合并 特殊 aac static
原文地址:http://www.cnblogs.com/lizo/p/7617299.html