微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java jvm垃圾收集算法

垃圾收集算法

1.分代收集理论:
垃圾收集器一般都采用分代收集算法,可以根据对象存活周期的不同将内存分为几块,一般都是把java堆分为年轻代和老年代,可以根据各个年代的特点选择合适的垃圾收集算法。
2.标记复制算法:
此种算法可以解决效率问题。它将内存分为大小相同的两块,每次使用其中的一块,当这一块的内存使用完以后,就将还存活的对象复制到另外一块去,然后再把使用的空间一次清理掉。每次内存的回收都是对内存的一半进行回收。

在这里插入图片描述

3.标记清除算法:
该算法分为标记和清除两个阶段,标记存活的对象,统一回收所有没有被标记的对象;也可以反过来,标记处所有需要回收的对象,在标记完成后,统一回收所有被标记的对象。这个是最基础的收集算法,但又如下缺点:
1.效率不高,如果标记的对象太多就不好
2.空间问题,标记清除后,会产生大量不连续的 碎片。

在这里插入图片描述

4.标记整理算法
根据老年代的 特点推出的一种算法,标记过程和标记清除算法差不多,但是后续步骤不是对可回收对象进行回收,而是让所有存活的对象移到一段,然后清理掉边界以外的内存。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐