java回收机制

昨晚看了看java回收机制,主要有以下几个机制:
(一),很简单但效率低下的引用计数法
该机制主要原理是这样,如果发现对象有引用,则计数器会+1,如果没有引用或者设为null时,则-1,当计数器为0时,执行垃圾回收,这样的话,即在整个过程中,都会执行计数算法,如果有对象与对象之间有互相引用,就会出现计数器不为0,但是应该回收的情况,这样就引来第二种机制:自适应机制。
(二)自适应机制
当执行垃圾回收时,系统会停止服务,在内存区合静态存储区中,查找对象的引用,如果发现“活”的对象,就复制到新的内存区中,更改对象的引用,查找完成后,清理旧的内存中的垃圾,这就是所谓的“停止-复制”模式。
如果内存中没有垃圾,或者垃圾很少的时候,这种模式就很占内存,这就引入了“标记-清除”模式,首先遍历对象图并标记可到达的对象,然后扫描堆栈以寻找未标记对象并释放它们的内存。
两种模式都是在停止运行程序的情况下执行。
当系统中有很大垃圾时,会执行“停止-复制”模式,如果垃圾较少时,会执行“标记-清楚”模式,这就是java的自适应机制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值