Java笔记4--JVM&GC
垃圾回收算法
1.引用计数法
2.复制算法 (新生代)
复制活的到空的(复 活)
复制之后有交换,谁空谁是To (To 0 --->往占用0的位置挪)
优点:没有产生内存碎片, 缺点:大对象复制耗时(所以用于新生代)
3.标记清除法 (老年代)
4.标记整理法 (老年代)
GC Roots 一定是从Roots开始的
可以作为GC Root的对象
盘点家底查看 JVM 默认值
- 查看初始默认值:-XX:+PrintFlagsInitial
ginseng@ginseng-pc:~/Project/demo$ java -XX:+PrintFlagsInitial
[Global flags]
intx ActiveProcessorCount = -1 {product}
uintx AdaptiveSizeDecrementScaleFactor = 4 {product}
uintx AdaptiveSizeMajorGCDecayTimeScale = 10 {product}
uintx AdaptiveSizePausePolicy = 0 {product}
uintx AdaptiveSizePolicyCollectionCostMargin = 50 {product}
uintx AdaptiveSizePolicyInitializingSteps = 20 {product}
uintx AdaptiveSizePolicyOutputInterval = 0 {product}
uintx AdaptiveSizePolicyWeight = 10 {product}
...
- 查看修改更新:-XX:+PrintFlagsFinal
bool UsePSAdaptiveSurvivorSizePolicy = true {product}
bool UseParNewGC = false {product}
bool UseParallelGC := true {product}
bool UseParallelOldGC = true {product}
bool UsePerfData = true {product}
bool UsePopCountInstruction = true {product}
bool UseRDPCForConstantTableBase = false {C2 product}
= 与 := 的区别是,一个是默认,一个是人物改变或者 jvm 加载时改变的参数
工作中常用的 JVM 配置参数
永久代用的是JVM的堆内存
通过-XX:+PrintGCDetails查看GC收集日志
该参数范围只能设置0~15(java8)
引用
强引用
软引用
弱引用
软/弱引用使用场景
虚引用
GC Roots和四大引用总结
OOM(常见)
GC Overhead
Direct buffer memory
通常因为NIO导致
unable to create new native thread
Metaspace
GC 收集器
其中,G1收集器是将堆内存分割成不同的区域然后并发的对其进行垃圾回收.
java8
新生代收集器
老年代收集器
CMS4步过程
1.初始标记
2.并发标记
3.重新标记
4.并发清除
四步总结
CSM优缺点:
优:并发收集低停顿
缺:1.采用标记清除算法会导致大量内存碎片
2.并发执行对CPU压力大
缺点主要原因
如何选择垃圾收集器
G1收集器
特点
G1底层原理
回收步骤
四步