JVM——GC垃圾回收V1.0.1

一.-x 和 -xx  参数

https://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html

X参数是非标准的参数

-Xint:解释执行    |    -Xcomp:第一次使用就编译成本地代码    |    -Xmixed:混合模式,jvm自己来决定是否编译成本地代码。

平时我们java -version看到的mixed mode就是这个意思:

XX参数是一种非标准化的参数,相对不是很稳定,用户可以自己设置,jvm调优和debug都是用这些参数。主要分为以下两大类:

1、Boolean类型

格式:-XX:[+-]<NAME>表示启用或者禁用name属性    |     比如:-XX:+UseConcMarkSweepGC   |   -XX:+UseG1GC

2、非Boolean类型

格式:-XX:<NAME>=<VALUE>表示name属性的值是value   |    比如:XX:MaxGCPauseMillis=500   |   XX:GCTimeRatio=19

3、特例

不是X参数,而是XX参数  |    -Xms等价于-XX:InitialHeapSize     |    -Xmx等价于-XX:MaxHeapSize

 

二.JVM之对象分配:栈上分配 & TLAB分配   https://blog.youkuaiyun.com/qq_30509055/article/details/93912227

-Xms20M  starting      堆的起始大小
-Xmx         max           堆的最大值
-Xmn         new           堆的新生代(影响新生代大小的参数   -XX:NewRatio=n)

对象分配eden  :-XX:SurvivorRatio=8    8:1:1

进入老年代配置

对象很大
    -XX:PretenureSizeThreshold=3145728   3M
长期存活的对象 
    -XX:MaxTenuringThreshold=15    【】
动态对象年龄判定
    相同年龄所有对象的大小总和 > Survivor空间的一半

分配担保
    Minor GC 之前检查 老年代最大可用连续空间是否>新生代所有对象总空间

    是否大于历代晋升老年代平均大小

Minor GC:新生代回收算法

Major GC:老年代回收算法

Full GC:Minor GC + Major GC【各种垃圾回收器最终目的是减少Full GC】

 

三.垃圾对象回收

JVM中的垃圾回收算法

1. 标记-清除(Mark-Sweep) 标记清除流程

jvm会扫描所有的对象实例,通过根搜索算法,将活跃对象进行标记,jvm再一次扫描所有对象,将未标记的对象进行清除,只有清除动作,不作任何的处理,这样导致的结果会存在很多的内存碎片。

2. 复制(copying)复制流程

jvm扫描所有对象,通过根搜索算法标记被引用的对象,之后会申请新的内存空间,将标记的对象复制到新的内存空间里,存活的对象复制完,会清空原来的内存空间,将新的内存最为jvm的对象存储空间。这样虽然解决了内存内存碎片问题,但是如果对象很多,重新申请新的内存空间会很大,在内存不足的场景下,会对jvm运行造成很大的影响

3. 标记-整理(Mark-compact)  标记整理流程

标记整理实际上是在标记清除算法上的优化,执行完标记清除全过程之后,再一次对内存进行整理,将所有存活对象统一向一端移动,这样解决了内存碎片问题。

4. 分代回收  分代回收算法

目前jvm常用回收算法就是分代回收,年轻代以复制算法为主,老年代以标记整理算法为主。原因是年轻代对象比较多,每次垃圾回收都有很多的垃圾对象回收,而且要尽可能快的减少生命周期短的对象,存活的对象较少,这时候复制算法比较适合,只要将有标记的对象复制到另一个内存区域,其余全部清除,并且复制的数量较少,效率较高;而老年代是年轻代筛选出来的对象,被标记比较高,需要删除的对象比较少,显然采用标记整理效率较高。

七种垃圾收集器https://blog.youkuaiyun.com/qq_30509055/article/details/94210131


        Serial【单线程】
        ParNew 【多个线程  默认】
            -XX:ParallelGCThreads
        Parallel Scavenge (全局)
            吞吐量 = 运行用户代码时间 / (运行用户代码时间  + 垃圾收集时间)
            -XX:MaxGCPauseMillis=n  【gc停顿时间 不建议设置 也不一定管用】
            -XX:GCTimeRatio=n 
            -XX:UseAdaptiveSizePolicy   GC  Ergonomics【】
        Serial Old
            CMS备用预案  Concurrent Mode Failusre时使用
            标记-整理算法
        Parallel Old
            标记-整理算法
        CMS
            标记-清除算法
            减少回收停顿时间
            碎片 -XX:CMSInitiatingOccupancyFraction  
            Concurrent Mode Failure 启用Serial Old
            -XX:+UseCMSCompactAtFullCollection
            -XX:CMSFullGCsBeforeCompaction 执行多少次不压缩FullGC后 来一次带压缩的 0 表示每次都压
            -XX:+UseConcMarkSweep并行与并发
        G1
            并行与并发;分代收集;空间整理 (标记整理算法,复制算法);可预测的停顿

应用线程和GC线程同步,GC运行时不是在任何时间节点让所有应用线程停止。有两种中断方式

抢占式:GC线程运行时应用线程会检查自己是否在安全点(执行比较久的构成之前或之后,例如:方法调用,异常跳转),如                    果在就停止,不在就继续运行至到安全点
主动式:GC线程运行时会设置flag ,当应用线程运行时会检查GC是否在运行,如果在运行则主动停止。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值