首先确定哪些是垃圾
1、引用计数法:
引用和对象是关联的,调用一个对象时必须引用他,如果一个对象引用数为0,则说明这个对象是可回收的。
2、可达性分析:
通过一系列gc roots对象作为起点搜索,如果gc roots和一个对象之间没有可达路径,则该对象不可达,不可达对象经过两次标记之后就会被回收。
GC算法:
1、标记清除法:
先标记所有需要回收的垃圾,然后回收。
2、复制算法:
将内存容量分为等大小的两块,每次只使用其中一块,当这一块内存满后将存活的对象复制到另一快,把已经使用过得那块内存清除。
3、标记整理算法:
先标记哪些对象清除,然后将存活对象移动到内存的一端,然后清除非存活对象。
4、分代收集算法:
分代收集算法是目前最常用的垃圾回收算法。核心思想是根据对象存活时间将内存划分为不同的域,一般情况下将GC堆划分为老生代和新生代,老生代的特点是每次只会回收少量对象,新生代是每次都有大量对象被回收。
新生代使用复制算法
老生代使用标记整理算法
jvm垃圾回收
最新推荐文章于 2024-01-17 16:29:27 发布