java学习个人笔记---内存管理之垃圾回收基本算法

垃圾回收基本算法

按基本的回收策略分:

(1)引用计数回收:
古老算法,对象每被引用一次,计数器加1,反之,对象每被删除引用一次,计数器减1;

 缺点是增加内存开销和无法处理相互引用的问题


(2)复制回收:

两个大小相同的内存空间A和B,将空间A中的可达对象找出来并复制到空闲的B空间中,将A空间中的所有对象回收;

 缺点是需要较大的复制成本和较多的内存


(3)不压缩回收(标志-清除):

先遍历空间中所有可达对象并做好标志,第二次遍历没有标志的对象直接清除回收;

内存利用率高,但缺点是产生较多的内存碎片


(4)压缩回收:

结合(2)和(3)的优点,先遍历空间中所有的可达对象并将它们集中起来,然后清除其他的对象并回收内存,避免产生内存碎片;



按系统线程分:

(1)串行回收:

单个线程回收,处理简单,无需多线程交互;

(2)并行回收:

多个线程回收,处理较复杂,但效率高;

(3)并发执行回收:

前两个是在程序暂停的情况下进行回收的,并发执行回收是在程序运行情况下,边执行边回收,缺点是耗内存和性能开销(要解决执行冲突,修改对象)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值