JVM--jvm垃圾收集(标记-清除,复制,标记-整理,分代)算法

1. 标记 - 清除算法 

标记清除算法是最基础的收集算法,其余收集算法都是基于这种思想。标记清除算法分为“标记”和清除”两个阶段:首先标记出须要回收的对象,标记完成以后统一清除对象。java

它的主要缺点:①.标记和清除过程效率不高 。算法

②.标记清除以后会产生大量不连续的内存碎片。spa

.net

2. 复制算法

它将可用内存容量划分为大小相等的两块,每次只使用其中的一块。当这一块用完以后,就将还存活的对象复制到另一块上面,而后在把已使用过的内存空间一次理掉。这样使得每次都是对其中的一块进行内存回收,不会产生碎片等状况,只要移动堆订的指针,按顺序分配内存便可,实现简单,运行高效。指针

主要缺点:内存缩小为原来的一半。orm

3. 标记  - 整理算法

标记操做和“标记-清除”算法一致,后续操做不仅是直接清理对象,而是在清理无用对象完成后让全部存活的对象都向一端移动,并更新引用其对象的指针。

主要缺点:在标记-清除的基础上还需进行对象的移动,成本相对较高,好处则是不会产生内存碎片。对象

四、分代收集算法 blog

根据对象的存活周期的不一样将内存划分为几块。通常把java堆分为新生代和老年代,这样就能够根据各个年代的特色采用最适当的收集算法。在新生代,每次垃圾收集时都发现有大批对象死去,只有少许存活,那就选用复制算法,只须要付出少许存活对象的复制成本就能够完成收集。而老年代中由于对象存活率高、没有额外空间对他进行分配担保,就必须使用“标记-整理”算法进行回收。内存



参考:http://blog.csdn.net/java2000_wl/article/details/8022293ci

相关文章
相关标签/搜索