Java虚拟机(JVM)的垃圾回收算法有很多种,其中比较常见的包括标记-清除算法(Mark-Sweep)、复制算法(Copying)、标记-整理算法(Mark-Compact)、分代算法(Generational)等。
标记-清除算法(Mark-Sweep):
原理:标记-清除算法分为两个阶段,首先从根节点开始标记所有可以访问到的对象,然后在清除阶段将未标记的对象进行清除。
场景:适用于内存碎片较多的场景,因为标记-清除算法不会移动对象,而是直接在原地清除未标记的对象。
复制算法(Copying):
原理:复制算法将堆内存分为两块,每次只使用其中一块。当一块内存满了之后,将存活的对象复制到另一块内存中,然后清除当前内存中的所有对象。
场景:适用于存活对象较少的场景,因为复制算法会产生较多的内存浪费。
标记-整理算法(Mark-Compact):
原理:标记-整理算法也是分为两个阶段,首先标记所有可以访问到的对象,然后将存活的对象向一端移动,然后清理掉另一端的内存。
场景:适用于内存碎片较多的场景,因为标记-整理算法可以减少内存碎片,提高内存利用率。
分代算法(Generational):
原理:分代算法根据对象的存活周期将堆内存分为不同的代,一般分为新生代和老年代。新生代使用复制算法,老年代使用标记-整理算法。
场景:适用于大部分场景,因为分代算法结合了多种算法的优点,能够在不同的代中选择合适的垃圾回收算法。
当你在Java中想要手动触发垃圾回收时,可以使用System.gc()方法或者Runtime.getRuntime().gc()方法:
1.使用System.gc()方法手动触发垃圾回收的示例代码:
public class GarbageCollectionExample {
public static void main(String[] args) {
// 创建大量对象,使得堆内存快速填满
for (int i = 0; i < 100000; i++) {
Object obj = new Object();
}
// 手动触发垃圾回收
System.gc();
}
}
2.使用Runtime.getRuntime().gc()方法手动触发垃圾回收的示例代码:
public class GarbageCollectionExample {
public static void main(String[] args) {
// 创建大量对象,使得堆内存快速填满
for (int i = 0; i < 100000; i++) {
Object obj = new Object();
}
// 手动触发垃圾回收
Runtime.getRuntime().gc();
}
}