JVM内容

JVM

  1. jvm内存结构。类加载器、运行时数据区、执行引擎…
    在这里插入图片描述
  2. 类加载器
    类加载方式:双亲委派机制
  3. 运行时数据区
    方法区(元空间),存储类字节码信息、静态变量、常量
    堆,存储对象信息。内存结构分为年轻代(1/3)(年轻代又分为Eden(8/10)、s0(1/10)、s1(1/10))、老年代(2/3)。
  4. 执行引擎
    对元空间中字节码文件顺序执行,程序计数器记录程序运行位置。执行引擎管理垃圾收集线程,对垃圾对象回收。
  5. 垃圾回收
    判断是否为垃圾对象:可达性分析 GC roots(根搜索算法)
    将GC root对象作为起点,从这个节点开始向下搜索引用对象,找到的对象都标记为非垃圾对象,其余未标记的对象都是垃圾对象。
    GC roots根节点:元空间中的静态变量引用、栈中引用、本地方法栈中引用
    在这里插入图片描述
    分代年龄:每经历一次GC后分代年龄增加1,当分代年龄增加到15之后,对象自动放入老年代。
    对象放入老年代规则
    1、正常的GC后,Eden区和s区已放不下对象,则放入老年代。
    2、幸存的对象过大,minorGC后,对象内存超过幸存区s0的1/2,直接放入老年代。
    3、分代年龄超过15之后,直接放入老年代。

在这里插入图片描述

  1. 双亲委派机制
    类加载器:根加载器、扩展类加载器、应用类加载器
    应用类加载器—>扩展类加载器—>根类加载器
  2. JNI:JAVA本地方法接口,调用底层程序接口。驱动本地程序,例打印机
  3. **GC垃圾回收主要是回收新生区。**也就是轻GC频率更高,fullGC频率要低一些。
    在这里插入图片描述
  4. 垃圾回收算法
    一、复制算法
    优点:不会产生碎片化内存
    缺点:幸存区中to区一直是空,浪费一部分内存。如果有太多的对象存活下来,复制算法如果都将存活下来的对象复制一遍,会消耗大量时间。
    所以复制算法比较适用于新生代垃圾回收。
    二、标记清除算法
    会产生大量的内存碎片,内存利用率比较低。
    三、标记压缩算法
    虽然内存利用率得到解决,但多了一次循环时间。
    老年代适应于:标记清除算法+标记压缩算法
  5. 垃圾收集器
    新生代收集器还是老年代收集器
    新生代收集器:Serial、ParNew、Parallel Scavenge
    老年代收集器:Serial Old、Parallel Old、CMS
    整堆收集器:G1
    吞吐量优先、停顿时间优先
    吞吐量优先:Parallel Scavenge收集器、Parallel Old 收集器
    停顿时间优先:CMS(Concurrent Mark-Sweep)收集器
    吞吐量与停顿适用场景
    停顿时间优先:交互多,对响应速度要求高
    吞吐量优先:交互少,计算多,适合在后台运算的场景
    串行并行并发
    串行:Serial、Serial Old
    并行:ParNew、Parallel Scavenge、Parallel Old
    并发:CMS、G1
    算法
    复制算法:Serial、ParNew、Parallel Scavenge、G1
    标记-清除:CMS
    标记-压缩:Serial Old、Parallel Old、G1
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值