一、如何判定对象为垃圾对象
1、可达性分析法(主流):一系列的称为 “GC Roots” 的对象为起始点,从这些点开始向下搜索,搜索所走的路径称为引用链,当一个对象到 GC Roots 没有任何引用链相连时,则证明此对象不可用。
GC Roots 对象包括:1、虚拟机栈中引用对象;2、方法区中类静态属性引用的对象;3、方法区中常量引用对象;4、本地方法栈中JNI(即 Native方法)引用对象。
2、引用计数算法:给对象添加一个计数器,每引用一次加 1;引用失效时减 1 ;任何时候计数器为0的都不可使用。
二、回收
一、常见的回收算法
- 标记清除:位置连续,产生碎片
- 拷贝算法:没有碎片,浪费空间
- 标记压缩:没有碎片,效率偏低
二、垃圾收收集器
1、Serial:新生代,单线程,串行回收
2、PS:年轻代并行回收
3、ParNew:新生代,多线程,配合CMS的并行回收
4、SeralOld
5、ParallelOld
6、Cms:老年代,并发的,垃圾回收和应用程序同时运行,降低STW是时间(200ms)
7、G1:(10ms)不分代
8、ZGC:(1ms)
9、Shenandoah
10、Eplison
1.8 默认垃圾回收器:PS + ParallelOld
三、JVM内存分代模型 (用于分代垃圾回收算法)
- 新生代 + 老年代 + 永久代(1.7)/ 元数据区(1.8)metaspace
1、永久代-元数据 Class
2、永久代必须指定大小限制,元数据可以设置,也可以不设置,无上限(受限于物理内存)
3、字符串常量 1.7-永久代 ; 1.8 - 堆
4、methodArea逻辑概念: 永久代 元数据 - 新生代=Eden + 2个suvivor区(s0 + s1)
1、YGC回收之后,大多数对象会被回收,活着的进入s0
2、再次YGC,活着对象eden + s0->s1
3、再次YGC,Eden + s1-> s0
4、年龄足够 ->老年代 (默认15 ;CMS 6)
5、s区装不下->老年代 - 老年代
1、顽固分子
2、老年代满了,FGC Full GC(整个内存区域) - GC Tuning(Generation)
1、尽量减少FGC
2、MinorGC=YGC 采用复制算法
3、MajorGC=FGC 标记清除算法 MajorGC 会产生内存碎片,为了减少内存损耗,一般需要进行合并或者标记出来方便下次直接分配。当老年代也满了装不下的时候,就会抛出 OOM(Out of Memory)异常
四、JVM 调优第一步
- JVM参数分类
1、标准:-开头,所有的HotSpot都支持
2、非标准:-X开头,特定版本的HotSpot支持特定的命令
3、不稳定:-XX开头,下个版本可能取消
-XX:+PrintCommandLineFlags 打印参数
-XX:+PrintFlagsFinal 最终参数值
-XX:+PrintFlagsslnitial 默认参数值