判定方法:
引用计数: 存储对特定对象的所有引用数, 回收引用计数为0的对象, 缺点是无法解决循环计数的问题(A 引用 B,B 引用 A)
引用链法: 通过一组 GC ROOT的对象作为起始点, 一个对象与GC ROOT没有引用链相连, 则说明对象可回收
可以作为GC ROOT的对象: java虚拟机栈中引用的对象, 本地方法栈中引用的对象, 方法区中静态属性引用的变量, 方法区中常量引用的变量
回收方法:
复制: 用于新生代, 将Eden区和from区中幸存的对象年龄加1, 如果年龄达到老年代要求, 则直接加入老年代, 没有则放入to区, 清空Eden和from区, 然后将to区的对象放入from区, 缺点是浪费内存空间
标记清除: 先标记需要清除的对象, 在统一回收, 缺点是会产生很多内存碎片
标记整理: 先标记需要清除的对象, 将存活对象移动到一端, 然后统一回收, 缺点是移动对象需要成本, 耗时