类装载系统执行引擎运行时数据区
内存模型
new出来的对象存放在堆里面年轻代(1/3占比),Eden(伊甸园去)8/10占比,servivor0 1/10占比,servivor1 1/10占比老年代(2/3占比):静态变量引用的对象、spring容器的bin对象、controller、service、线程池、对象池、缓存对象…gc roots:线程栈、方法区两部分存放的本地变量、静态变量、本地方法栈的变量。gc时将gc roots 对象作为起点,从这些节点开始向下搜索引用对象,找到的对象标记为非垃圾对象,其余未标记的对象是垃圾对象。可达性分析算法:分代年龄:对象每经历一次gc,没有清除掉分代年龄会加1,年轻代中分代年龄达到15后会将对象移动到老年代中。minor gc:Eden(伊甸园去)8/10占比内存放满后会触发minor gc,回收年轻代的垃圾对象。gc期间会发生STW stop the world,但是持续时间会很短,几乎无影响。full gc:回收年轻代和老年代整个堆的内存空间进行垃圾回收。gc期间会发生STW stop the world。暂停用户线程,待回收后才可用。jvisualvm:jvm调优的可视化工具,需要配置插件 2、方法区 3、栈(线程)
程序运行main方法后会在栈中开辟一块独立的栈空间(专属的内存区域),区分不同方法的局部变量,即栈帧内存区域。与数据结构中的栈类似,程序中方法先调用后结束。占中包含 局部变量、操作数栈、动态链接、方法出口。 4、本地方法栈 5、程序计数器 类装载系统 字节码执行引擎
负责垃圾回收 jvm调优
减少full gc分析每个对象的大小,每个对象的字节的总数*峰值的对象数量 垃圾回收算法
1、标记清除法
会产生磁盘碎片,磁盘空间不连续
2、标记复制
没有碎片,浪费空间
3、标记整理算法
没有碎片,效率偏低
Serial 是一款用于新生代的单线程收集器,采用复制算法进行垃圾收集适用场景:Client 模式(桌面应用);单核服务器。可以用 -XX:+UserSerialGC 来选择 Serial 作为新生代收集器。 1.1.2 ParNew 收集器
ParNew 就是一个 Serial 的多线程版本通过 -XX:ParallelGCThreads 来设置垃圾收集的线程数默认开启的收集线程数和 CPU 数量一致适用场景:多核服务器 1.1.3 Parallel Scavenge 收集器
一款用于新生代的多线程收集器Parallel Scavenge 的目标是达到一个可控制的吞吐量吞吐量 = 运行用户代代码时间/(运行用户代码时间+垃圾收集时间)适用场景:注重吞吐量,高效利用 CPU,需要高效运算且不需要太多交互 1.2 老年代垃圾收集器 1.2.1 Serial Old 收集器
Serial Old 收集器是 Serial 的老年代版本,同样是一个单线程收集器,采用标记-整理算法。适用场景:Client 模式(桌面应用),单核服务器与 Parallel Scavenge 收集器搭配,作为 CMS 收集器的后备预案 1.2.2 CMS(Concurrent Mark Sweep) 收集器
以最短回收停顿时间为目标的收集器 1.2.3 Parallel Old 收集器
Parallel Scavenge 的老年代版本,是一个多线程收集器,采用标记-整理算法 GC发展阶段
Serial => Parallel (并行) => CMS(并发) => G1 => ZGC



