引用计数法:
频繁计数影响性能,无法处理循环引用问题
标记清除:
标记:遍历所有的GC Roots,并将从GC Roots可达的对象设置为存活对象;
清除:遍历堆中的所有对象,将没有被标记可达的对象清除;
大量的内存遍历工作,所以执行性能较低
内存不连续,空间浪费
标记清除整理:
在进行完标记清除之后,对内存空间进行压缩,节省内存空间,解决了标记清除算法内存不连续的问题。
节省内存空间,解决了标记清除算法内存不连续
复制算法:
内存一分为二,存活对象复制到空白内存,最后将正在使用的内存空间的对象清除
简洁高效
不适合用于存活对象多的情况,因为那样需要复制的对象很多
复制算法往往用于内存空间中新生代的垃圾回收,因为新生代中存活对象较少,复制成本较低
备注:
新生代 存活对象少 复制算法
老年代 存活对象多 标记清除整理
JVM常见垃圾回收算法(引用计数,标记清除,标记整理,复制)
于 2020-08-21 17:23:28 首次发布