深刻理解Java虚拟机(2)

一、GC过程

二、对象已死判断算法

  

三、对象的引用:

 

四、垃圾收集算法

补充堆中区域划分算法

五、垃圾收集器

Parallel Scavenge:吞吐量优先收集器,与ParNew区别在于多了自适应调节策略并发

CMS:以获取最短回收停顿时间为目标的收集器,是基于标记-清除算法实现的收集器。spa

 

补充两个概念:线程

并行(Parallel):指多个垃圾收集线程工做、但此时用户线程仍然处于等待状态。对象

并发(ConCurrent):指用户线程与垃圾收集线程同时执行。内存

 

六、内存分配过程

通常过程:io

一、TLAB((Thread Local Allocation Buffer))引用

二、优先堆新生代eden区并行

三、大对象进入堆老年代自适应

四、新生代GC(Minor GC)发生,存活对象则优先新生代Survivor区,若存活对象大于Survivor区,则经过担保机制进入老年代。

 

1)默认新生代Eden、Survivor比例是多少?

-8:1,整个新生代包括Eden区和2个Survivor区,也就是若是新生代共10M,则Eden分配8M,2个Survivor各为1M。

-XX:SurvivorRatio=8设置比例值。

 

2)新生代GC和老年代GC的有啥不同?

-新生代GC发生频繁,速度快

-新生代GC采用复制算法,老年代GC采用标记整理算法

 

3)新生代Survivor区的对象如何进入老年代?

-Survivor存活年龄(新生代GC一次,年龄+1)大于MaxTenuringThreshold值。

-相同年龄的对象之和大于Survivor大小的一半

相关文章
相关标签/搜索