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

标记—清除算法

 1)标记阶段:先通过根节点,标记所有从根节点开始的对象,未被标记的为垃圾对象

 2)清除阶段:清除所有未被标记的对象

复制算法:

   将原有的内存空间分成两块,每次只使用其中一块,在垃圾回收时,将正在使用的内存中的存活对象复制到未使用的内存块中,然后清除正在使用的内存块中的所有对象。

标记—整理算法:(若对象存活率比较高,就要进行多次复制,效率比较低)

   1)标记阶段:先通过根节点,标记所有从根节点开始的可达对象,未被标记的为垃圾对象(会出现磁盘碎片)。

(2)整理阶段:将所有的存活对象压缩到内存的一段(或向一端移动),之后清理边界所有的空间

分代收集算法:

只是根据对象存活周期的不同将内存划分为几块。一般把java堆分为新生代和老年代。

新生代大量对象死亡,只有少数对象存活,采用复制算法

老年代对象存活率高,没有额外空间对它进行分配,故采用标记--清理或标记--整理算法

三种算法的比较:

  1)效率:复制算法>标记/整理算法>标记/清除算法(此处的效率只是简单的对比时间复杂度)

  2)内存整理度:复制算法=标记/整理算法》标记、清除算法

  3)内存利用率:标记/整理算法=标记/清除算法》复制算法

内存的分配

1、大多数新生的对象在Eden区分配,当Eden区没有足够空间进行分配时,虚拟机就会进行一次Minor GC.(Survivor是两个)

 新生代:
    在方法中去new一个对象,那这方法调用完毕后,对象就会被回收,这就是一个典型的新生代对象。(新生对象在eden区经历过一次minorG并且被Survivor容纳的话,就对象年龄为1,每一次熬过MinorGc 就会年龄加1,直到15,就会晋升到老年代)

注意动态对象的判定:Survivor空间中相同年龄的对象大小总和大于Survivo空间的一半,大于或等于该年龄的对象就可以直接进入老年代。

老年代:

1)在新生代中经历了N次垃圾回收后仍然存活的对象,就会被放到老年代中,而且大对象(大量连续内存空间的java对象如很长的字符串及数组)直接进入老年代。

2)当survivor空间不够用时,需要依赖老年代进行分配担保。

永久代:

   即方法区


你可能感兴趣的:(jvm)