很多系统的垃圾回收是一种计数技术:
每个对象有个计数器,当该对象被引用时,计数器加一 ,当引用被置为NULL或者离开作用域时,引用计数减一,
但是Java不是这种技术,因为这种技术有自身缺陷:
设想,有三个对象互相引用,构成一个圆圈,这样就会出现,对象应该被回收但是计数器不为0的情况
还有更快的模式
遍历每个活的对象(被引用的i情况下会穿越几个对象层次),到达该对象的引用,看该对象的引用,
结束后,由引用遍历对象,再遍历这个对象的所有引用,,,,(,这一点不是太清楚 )
java的自适应的垃圾回收技术:停止-复制
暂停程序运行 ,把所有程序中活着的对象复制到另一个堆,同时更新引用的指针。
由于堆堆之间的复制消耗太大,Java把堆分为几个块,使用的块块复制的方式
Java的另外一种方式:标记--清扫
在垃圾特别少的情况下,反复复制消耗相对还是太大
这时,Java会转换位标记清扫法,标记所有的活的对象,并且标记,标记结束后进行清扫。