GC介绍

GC介绍

JVM在进行GC时,并不是对这三个区域进行统一回收,大部分时候都是在新生区

  • 新生区

  • 幸存区:【fromto

  • 老年区

    GC两种类:轻GC(普通垃圾回收)、重GC(全局垃圾回收)

  • GC主要存在于方法区和堆中

  • 面试题目

  • 引用计数器:会有循环引用的问题,不经常使用!

  • 复制算法

    img

    可以简单的说GC复制算法就是作用于新生区的 from和to区

    • 好处:没有内存碎片
    • 坏处:也就是浪费了一个幸存者区也就是to区,复制算法上面也说了就是to区永远都是空的
      最佳使用场景:新生区,毕竟嘛对象存活率较低
  • 标记清除压缩算法

    img

  • 标记清除算法:

    • 好处:不需要额外的空间
    • 坏处:消耗时间多,标记一次、清除一次,有内存碎片
  • 标记压缩算法:清除了内存碎片,但是又加长了时间,应该说是用时间换空间

  • 总结

    内存效率:复制算法>标记清除法>标记压缩法

    内存整齐度:复制算法=标记压缩法>标记清除法

    内存利用率:标记压缩法=标记清除法>复制算法

    所以说算法没有最优的,只有最合适的_GC:又叫分代收集算法

年轻代:存活率低,复制算法很合适
老年代:区域大,标记清除(内存碎片不是很多)+标记压缩混合使用

posted @ 2021-05-02 09:04  saxon宋  阅读(573)  评论(0)    收藏  举报