JVM 垃圾回收算法
网上有很多总结很好的。先放个占位在这。
-
标记-清除法 这是一个间接回收算法, 它通过确定哪些是存活的对象,来确认哪些是垃圾。这种算法每次都需要重新计算存活的对象。
-
引用计数法(Reference Counting Collector) 这种方法中,堆中每个对象实例都有一个引用计数。当一个对象被创建时,且将该对象实例分配给一个变量,该变量计数设置为1。当任何其它变量被赋值为这个对象的引用时,计数加1(a = b,则b引用的对象实例的计数器+1),但当一个对象实例的某个引用超过了生命周期或者被设置为一个新值时,对象实例的引用计数器减1。任何引用计数器为0的对象实例可以被当作垃圾收集。当一个对象实例被垃圾收集时,它引用的任何对象实例的引用计数器减1 注意: 1.这种方法,可以很快的执行,交织在程序运行中。对程序需要不被长时间打断的实时环境比较有利。2.无法检测出循环引用。3. 给赋值器带来额外的时间开销。 4.引用计数的操作必须是原子操作。4. 引用极速发可能导致停顿,比如删除某一大型指针,这种算法会更新删除节点的子节点。