java 快速回收_Java:垃圾回收算法

##常见算法

引用计数:循环引用问题

标记-清除算法:速度快,但有内存碎片

标记-整理算法:速度慢,无内存碎片

复制算法:无内存碎片,占用内存大

分代垃圾收集:综合若干算法

##资料

##问题

###1、引用计数中,循环引用如何产生? 例如这段代码(来自深入理解java垃圾回收机制 ):

public class Main {

public static void main(String[] args) {

MyObject object1 = new MyObject();

MyObject object2 = new MyObject();

object1.object = object2;

object2.object = object1;

// 试图清理

object1 = null;

object2 = null;

}

}

如果采用引用计数,那么在// 试图清理之前:

c13f1db64d8941bc21ea201448610227.png

object1 = null;

object2 = null;

之后:

5bf661e708f5ddf376435b25e47b3821.png

两个对象之间仍然存在互相引用,可惜没有变量名可以访问它们了...

###2、如何标记-整理? 若对象A中引用了B,当对B进行挪动时,如何保证A保存的B的位置仍然是B?

不清楚,这个是底层实现的问题。一个思路:B中也存放(隐式存放,不当作引用)了A的位置,当B的位置变化,B可以通知A更新B的位置。

在基于Compacting算法(例如标记-整理)的收集器的实现中,一般增加句柄和句柄表。

###3、为什么标记-整理比标记-清除慢? 标记-整理的第1步是标记-清除,之后进行整理,多了一个整理的时间。

###4、复制算法比标记整理算法更? 快一些。复制算法的目标是为了克服句柄的开销和解决堆碎片。

###5、标记-清除算法中标记的什么?清除的什么? 标记存活的对象,删除未被标记的对象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java垃圾回收算法主要基于可达性分析和标记-清除两种算法。下面是对这两种算法的简要说明: 1. 可达性分析 (Reachability Analysis):这是Java垃圾回收的基础算法。它通过判断对象是否可以从根对象(如线程栈、静态变量等)访问到来确定对象的存活状态。如果一个对象不可达,则认为它是垃圾,可以被回收。 2. 标记-清除 (Mark and Sweep):这是最基本的垃圾回收算法之一。在标记阶段,垃圾回收器从根对象开始遍历所有可达对象,并将其标记为“存活”。在清除阶段,垃圾回收器清除所有未被标记的对象,并回收它们所占用的内存空间。 除了标记-清除算法Java还使用了其他一些高级的垃圾回收算法,包括: 1. 复制算法 (Copying Algorithm):将堆内存分为两个区域,每次只使用其中一个区域。当一个区域满了之后,将存活的对象复制到另一个区域中,并清除当前区域中的所有对象。 2. 标记-整理 (Mark and Compact):类似于标记-清除算法,但在清除阶段之后,它会将存活的对象移动到内存的一端,以便于分配连续的内存空间。 3. 分代算法 (Generational Algorithm):根据对象的存活时间将堆内存划分为不同的代。通常情况下,新创建的对象会被分配到年轻代,而存活时间较长的对象则会被转移到老年代。不同代使用不同的垃圾回收算法进行回收。 这些算法的选择取决于具体的应用场景和性能需求,Java垃圾回收器通常会根据当前堆内存的使用情况和对象的存活特性来选择合适的回收算法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值