
JVM垃圾回收算法
标记-清除算法
该算法分为“标记”和“清除”阶段:首先标记出所有需要回收的对象,在标记完成后统一回收掉所有被标记的对象。也可以反过来先标记所有不需要被回收的对象,标记完成以后回收没有被标记的对象。
优缺点:
执行效率不稳定,适用于对象存过较多的区域,适用于老年代
会产生内存碎片
何为清除?
标记清除并不是真的置空,而是把需要清除的对象地址保存在空闲的地址列表里。下次有新对象需要加载时,判断垃圾的位置空间是否够,如果够,就存放。
复制算法
将可用内存分为大小相同的两块,每次使用其中的一块。当这一块的内存使用完后,就将还存活的对象复制到另一块去,然后再把使用的空间一次清理掉。这样就使每次的内存回收都是对内存区间的一半进行回收。
优点:
不会出现内存碎片问题 对于存活对象少的区域(新生代),简单高效
缺点
将可用内存减少到一半

JVM垃圾回收包括标记-清除、复制、标记-整理和分代收集四种算法。复制算法适用于新生代,标记-整理适合老年代。常见的垃圾回收器如Serial、ParNew、Parallel Scavenge、Serial Old、Parallel Old、CMS和G1各有特点,分别采用了不同的算法。CMS追求低停顿,G1兼顾低停顿和大空间。了解这些算法有助于优化Java应用的性能。
最低0.47元/天 解锁文章
587

被折叠的 条评论
为什么被折叠?



