JVM GC 算法

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/ocp114/article/details/82794850

一、GC 算法分类

  1. 引用计数法: Java 中并没有使用,Python 有
    引用计数法
  2. 标记清除: 遍历所有根对象,把非垃圾数据标记,清除垃圾数据
    标记清除
  3. 标记压缩: 遍历所有根对象,把非垃圾数据标记,移动非垃圾数据到一片连续的内存空间
     标记压缩
  4. 复制算法: 和标记压缩有点像,但是标记压缩是把数据移动到同一片内存空间,而复制算法是复制到另外一片内存空间中,在 JVM 的内存模型中,在新生代有 eden space、 from space 和 to space 三块内存空间,其中下面的两个用于复制算法的内存空间就是 from space 和 to space,一般存放着小对象和来源于 eden space,大对象大多会直接进入老年代
    复制算法复制算法

二、相关名词解释

  1. 根: 可以是栈中引用的对象、静态变量或静态变量引用的对象、JNI 方法栈中引用的对象
  2. 可触及性: 从根出发,能够一直往下触及/指向的对象
  3. 可复活性: 在执行 GC 时,会调用对象的 finalize() 方法,即使对象被赋空,如果这个方法被重写,是的这个对象又持有引用,那么该对象就可以复活,不会被 GC 了
  4. 不可复活性: 在执行 GC 时,如果 finalize() 方法被重写并且没有为对象重新赋值重新持有引用,那么,执行了 finalize() 方法后,该对象就会变成不可复活状态,等待回收
  5. stop the world: 在进行 GC 时,所有 Java 代码被停止,线程挂起,造成全局停顿现象,所以要控制好 GC,不然有可能引起死锁、dupm 线程等问题

猜你喜欢

转载自blog.csdn.net/ocp114/article/details/82794850