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