Java垃圾回收机制(详解)

查找垃圾——垃圾搜索算法:
引用计数器:系统给每一个对象创建一个引用计数器,当对象被引用时,计数器+1,当对象失去引用时,计数器-1,当计数器值为0时,系统判断该对象为“垃圾”,需要被回收,该算法由于无法解决对象被循环引用的情况,以及计数器不断的加1减1增加了系统的开销,因此在jdk1.1之后就被弃用了。
GC算法:由于目前该方法被广泛使用,因此垃圾搜索算法又叫GC算法,该算法是以一些GC Roots对象为起点,沿着从上至下的顺序遍历,经过的路径称为引用链,当发现有对象不在引用链上,系统就将该对象认定为“垃圾”,需要被回收。
垃圾清除算法:
标记——清除算法:就是将系统确认的垃圾进行标记,再进行清除,现在一般不用。
复制算法:将内存分为大小相等的两块内存,在其中一块内存中存储对象,将不需要清除的对象复制到另一块内存中,然后将原内存清空。但是由于对内存浪费较多,因此一般用于对新生代的对象进行垃圾回收。
标记——整理算法:首先使用复制算法,将内存分为大小两部分,在其中一块内存存储对象,将不需要被清除的对象移动至内存快的一端,然后将该内存块的其他部分清除。一般用于老年代对象的垃圾回收。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值