通过垃圾回收期对对象重新排列,实现了一种高速的、有无限空间可供分配的堆模型。
活 的对象
如果从堆栈和静态区域开始,遍历所有的引用,就能找到所有的“活”的对象;对于发现的每个引用,追踪到它的每个对象,然后此对象包含的所有引用,如此反复进行,直到“根源于堆栈和静态存储区的引用”所形成的网络全部被访问为止,访问过的对象都是“活”的。
java虚拟机采用了一种“自适应”的垃圾回收技术:
有一种做法叫“停止-复制”,意思是:先暂停程序的运行,然后将所有存活的对象从当前堆复制到另一个堆,没有被复制的全部是垃圾;当对象被复制到新堆时,他们是一个 挨着一个的,以新堆保持紧密排列;(效率低。)
为了避免效率低下;一些jvm会自查,如果没有新垃圾产生,会转换到另一种模式“标记-清扫”,意思是:从堆栈和静态存储区出发,遍历所有的引用,进而找出所有存活 的对象,然后给该对象一个标记,这个过程中不会回收任何对象。只有全部标记工作完成的时候,清理动作才会开始。而清理动作开始时,没有标记的对象会被释放,不会有复制动作。剩下的堆空间不是连续的,垃圾回收器要是想得到连续空间,需要重新整理剩下的对象。
两种模式并不是在后台运行,意思是必须在程序暂停的时候运行;