• JVM——垃圾收集算法及垃圾回收器


    一、垃圾回收算法

    1、标记—清除算法

    1)工作流程

    算法分为“标记”和“清除”阶段:首先标记出所有需要回收的对象(标记阶段),在标记完成后统一回收所有被标记的对象(回收阶段)。

    2)缺点

    a. 效率问题:标记和清除这两个过程的效率都不高。

    b. 空间问题:会产生大量的不连续碎片。


    2、复制算法(新生代垃圾回收算法)

    1)工作流程

        将内存划分为大小相等的两块,每块只使用其中的一块,另外一块作为保留区域,当进行垃圾回收时,将使用区域的存活对象一次性进行赋值到保留区域,而后一次性清空使用区域。

    2)使用场景

         新生代垃圾回收,新生代对象具有朝生夕灭的特性(新生代对象存活率低)。

    3)优点:实现简单,运行效率高,无空间碎片问题。

    4)JVM采用的复制算法:

       将内存划分(新生代内存)为一块较大的Eden区域和两块大小相等、空间较小的Survivor区域(EdenSurvivor = 8:1)。

       每次使用Eden和其中的一块Survivor区域(第一块Survivor区域为from区域,另外一块为to区域)。

       在进行垃圾回收时(Eden区域快满时,系统自动触发垃圾回收)

    A. 第一次进行GC时,将Eden区中的对象移动到from区域。

    B. 第二次再进行GC时,将Eden区和from区中存活的对象移动到to区域,然后一次性清除掉Edenfrom区,以此循环。

    C. 对象在from区域和to区域来回移动15次(默认),将对象移动到老年代。

    D. 特殊情况:当Survivor区域放不下存活对象时,会从老年代进行分配担保。


    3、标记整理算法(老年代回收算法)

    复制算法在对象存活率比较高的情况下,会有大量对象复制操作,效率很低,因此,老年代不采用复制算法。

    1)工作流程:

           标记阶段和标记清除阶段的标记类似,标记出无用对象。

           整理阶段:将存活对象向一端移动,而后一次性将存活对象边界以外的空间清除掉。

    4、分代回收算法

       Java采用分代回收算法,即新生代采用复制算法,而老年代采用标记整理算法。

       将内存划分为新生代(对象存活率低)和老年代(对象存活率高)。


    面试考点:请问了解Minor GCMajor GC吗?

    Minor GC:新生代GC,指的是新生代垃圾回收,在新生代中,对象大多数朝生夕灭,因此采用复制算法,Major GC发生频繁,效率较高,

    Major GC (老年代GC/Full GC):指的是发生在老年代的垃圾回收,发生Full GC通常会至少发生一次Minor GC,但并非绝对,Full GC 速度比Minor G从速度慢10倍以上,发生频率较低。

    二、垃圾回收器

    并行:指的是多条垃圾回收线程并行工作,而用户线程等待。

    并发:用户线程与垃圾回收线程同时执行(不一定并行,可能交替执行),用户线程继续执行,垃圾回收线程运行在另外的内核中。

    吞吐量:CPU运行用户代码时间/CPU总时间

            CPU总时间即用户代码时间+垃圾回收时间

    新生代垃圾回收器:SerialParNewParallel scavenge

    老年代垃圾回收器:SeralOldParallelOldCMS

    全区域垃圾回收器:G1

    1、Serial收集器(新生代垃圾回收,串行收集器)

    (1)特性:Serial是一个单线程收集器,在Serial进行垃圾收集时,必须暂停其他所有的工作线程,直到Serial收集器手机结束(STW)。

    (2)应用场景:Serial收集器是JVM运行在Client模式下默认的新生代收集器。

    (3)优点:简单而高效,对于单核CPUSerial收集器由于没有线程交互开销,可以获得最高的单线程收集效率。

    2、ParNew收集器(新生代收集器,并行GC

    (1)特性:ParNew收集器是Serial收集器的多线程版本。

    (2)应用场景:PerNew是许多运行在Serial模式下的JVM首选新生代收集器。

    (3)优点:随着可使用CPU数量的增加,对于GC时系统资源的利用有较大帮助。

    3、Parallel Scavenge 收集器(吞吐量有限收集器,新生代收集器,并行GC

    (1)特性:吞吐量

       两个参数控制吞吐量:

       a. .-xx:MaxGCPauseMillis:控制最大垃圾收集器停顿时间。

       b. .-xx:GCRatio:直接设置吞吐量大小

    (2)应用场景:高吞吐量场景,适合需要与用户交互的程序(B/S架构),良好的响应速度提升用户体验。

    (3)优点:与ParNew收集器比较:高吞吐量。

          GC自调节策略(-xx+UseAdaptiveSizePolicy

    4、Serial Old收集器(老年代收集器,并行GC

    (1)特性:Serial OldSerial老年代版本,单线程收集器,实用标记整理算法。

    (2)应用场景:

         1)Client模式下:Serial Old主要也在于给Client模式下的虚拟机使用。

         2)Server模式下:作为CMS收集器的后备预案,当CMS发生并发失败问题时使用。

    5、Parallel Old收集器(老年代收集器,并行GC

    (1)特性:Parallel OldParallel Scavenge老年代版本。

    (2)应用场景:注重吞吐量以及CPU资源敏感场合。

    6、CMS(老年代垃圾收集器,并行GC):采用标记清除算法

    (1)特性:CMS收集器是以获得最短系统停顿时间为目标的垃圾回收器。

    (2)应用场景:B/S系统:服务端。B/S系统重视服务器的响应速度,希望系统停顿时间尽可能短,CMS收集器非常符合此类应用需求。

    (3)优点:并发收集,低停顿。

    (4)缺点:对CPU资源敏感,产生大量空间碎片。

    7、G1(全区域垃圾回收器)

    应用场景:应用于低停顿场景。


  • 相关阅读:
    jQuery Mobile动态刷新页面样式
    IE10下阿里旺旺无法快速登录解决办法
    JS复制内容到剪贴板: 兼容IE、Firefox、Chrome、Safari所有浏览器【转】
    python sftp ftp 造轮子,实现多个方法
    synergy ubuntu18.04 windows10
    爬虫之js破解 非常详细
    scrapy的useragent与代理ip
    Xpath的string(.)用法
    selenium cookie 登录
    scrapy爬取迅雷电影天堂最新电影ed2k
  • 原文地址:https://www.cnblogs.com/edda/p/12602207.html
Copyright © 2020-2023  润新知