zoukankan      html  css  js  c++  java
  • jvm的垃圾回收

    首先类加载的过程:加载验证准备解析初始化

     类加载器:

     jvm内存模型图:

    空着,等以后补上

    jvm垃圾收集器

    目前只知道,parnew,cms,g1

    parnew新生代垃圾回收器,复制算法

    cms复制整理算法

    相关概念:年轻代(eden,s0,s1),老年代,永久代

    minorGC年轻代 ,fullGC 全部gc,作用在老年代

    年轻代的gc停顿时间短,老年代停顿时间长

    优化思路尽量让短时间存活的对象保存在年轻代,如果是大对象直接进入老年代,避免频繁移动。

    避免出现动态年龄规划,进入老年代

    避免出现s区内存大小达不到eden区存活对象的大小导致对象直接进入老年代在JVM内存分配中,有几个参数是比较核心的,如下所示。

    -Xms:Java堆内存的大小
    -Xmx:Java堆内存的最大大小
    -Xmn:Java堆内存中的新生代大小,扣除新生代剩下的就是老年代的内存大小了
    -XX:PermSize:永久代大小
    -XX:MaxPermSize:永久代最大大小
    -Xss:每个线程的栈内存大小

    模拟参数: -Xms512M -Xmx512M -Xmn256M -Xss1M -XX:PermSize=128M -XX:MaxPermSize=128M

    parnew垃圾收集器特点:

    适用于程序内存小,平均对象存活时间短,能和cms配合使用,适用于新生代。

    复制算法,将内存分为两块s0,s1,当eden区满了,就把存活对象复制移动到s0或s1区保证每次有一个区是空的,清除eden区,没有垃圾碎片。stw时间短。

     1.关于动态年龄审核

    2.关于大于50%直接进入老年区

    3.大内存对象直接进入老年区

     4.15次young gc之后还存活的对象,直接进入老年代

    cms垃圾收集器特点:

    内存标记,内存移动整理,多线程处理,重复标记,最后再进行内存回收。

    标记清除整理算法:

    1.将gcroot直接引用的对象进行标记,stw

    2.不stw,和系统并行,追踪第一步标记gcroot的,会有新的对象进来,标记变成垃圾的。

    3.判断被标记对象是否可达,改动对象从存活到垃圾的对象,就会被清理掉了 

    4.清理前几个阶段被标记的对象。

    g1垃圾回收器特点:

    大内存空间使用最佳,大内存使用parnew的时候清理空间时间会长一点,g1可以设置停顿多少时间进行清理空间,做到用户无感知。

    g1内存分配,把内存分成2048分region

    g1对象空间分代和上面一样,也是分老年代,青年代。

    g1运行原理也是eden满了就放入s0,s1,达到年龄审查就进入老年代

    g1区大对象有单独的管理大对象的region。

    进入老年代的原因和上面一样,不过大对象是直接在eden区了。

    老年代垃圾回收:

    1.初始标记

    2.并发标记
    3.重新标记
    4.混合回收

  • 相关阅读:
    poj 2955 Brackets
    HDU 3790 最短路径问题
    畅通工程续
    HDU 1896 六度分离
    HDU
    第九周作业
    第八周作业
    2019年春季学习第七周学习总结
    2019春季学习总结第六周作业
    第五周作业
  • 原文地址:https://www.cnblogs.com/q1359720840/p/15093204.html
Copyright © 2011-2022 走看看