GC介绍

2021/5/2 10:27:16

本文主要是介绍GC介绍,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

GC介绍

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

  • 新生区

  • 幸存区:【fromto

  • 老年区

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

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

  • 面试题目

    • JVM的内存模型和分区【详细到每个区放什么】
    • 堆里面的分区有哪些?新生区【Eden,from,to】、老年区,说说他们的特点
    • GC算法有哪些?标记清除法、标记整理/标记压缩、复制算法、引用计数器,怎么用?
    • 轻GC和重GC分别在什么时候发生?
  • 引用计数器:会有循环引用的问题,不经常使用!

  • 复制算法

    img

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

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

    img

  • 标记清除算法:

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

  • 总结

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

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

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

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

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



这篇关于GC介绍的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程