JVM优化:个人备注回忆

运行:

数据:方法区、堆

指令:程序计数器、虚拟机栈、本地方法栈

强引用、软引用

软引用:缓存

方法论
        标记-清除算法
        复制回收算法
        标记-整理算法
    垃圾收集器
        STW  Stop The World
        Serial
        ParNew 
            -XX:ParallelGCThreads
        Parallel Scavenge (全局)
            吞吐量 = 运行用户代码时间 / (运行用户代码时间  + 垃圾收集时间)
            -XX:MaxGCPauseMillis=n
            -XX:GCTimeRatio=n
            -XX:UseAdaptiveSizePolicy   GC  Ergonomics
        Serial Old
            CMS备用预案  Concurrent Mode Failusre时使用
            标记-整理算法
        Parallel Old
            标记-整理算法
        CMS
            标记-清除算法
            减少回收停顿时间
            碎片 -XX:CMSInitiationgOccupancyFraction  
            Concurrent Mode Failure 启用Serial Old
            
            -XX:+UseCMSCompactAtFullCollection
            -XX:CMSFullGCsBeforeCompaction 执行多少次不压缩FullGC后 来一次带压缩的 0 表示每次都压
            -XX:+UseConcMarkSweep

         有俩次swt,分别在初始化标记(确认GC-ROOT),再标记阶段(标记垃圾)

         浮动垃圾:因为GC、和应用程序的线程同时执行,标记垃圾后,某些变量可能无用了,只能下次在标记清理,就是浮动垃圾

CMS占用空间较大,
        G1

    

 

串行收集器:在年轻代和老年代都采用单线程,年轻代中使用 stop-the-world、复制 算法;老年代使用 stop-the-world、标记 -> 清理 -> 压缩 算法。

并行收集器:在年轻代中使用 并行、stop-the-world、复制 算法;老年代使用串行收集器的 串行、stop-the-world、标记 -> 清理 -> 压缩 算法。

并行压缩收集器:在年轻代中使用并行收集器的 并行、stop-the-world、复制 算法;老年代使用 并行、stop-the-world、标记 -> 清理 -> 压缩 算法。和并行收集器的区别是老年代使用了并行。

CMS 收集器:在年轻使用并行收集器的 并行、stop-the-world、复制 算法;老年代使用 并发、标记 -> 清理 算法,不压缩。本文介绍的唯一一个并发收集器,也是唯一一个不对老年代进行压缩的收集器。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值