Java笔记4--JVM&GC

2019-07-23  本文已影响0人  执壹
image.png image.png

垃圾回收算法

1.引用计数法

image.png

2.复制算法 (新生代)

image.png

复制活的到空的(复 活)

image.png

复制之后有交换,谁空谁是To (To 0 --->往占用0的位置挪)
优点:没有产生内存碎片, 缺点:大对象复制耗时(所以用于新生代)

3.标记清除法 (老年代)

image.png

4.标记整理法 (老年代)

image.png image.png t

GC Roots 一定是从Roots开始的

可以作为GC Root的对象

image.png image.png

盘点家底查看 JVM 默认值

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}
   ...
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 配置参数

image.png

永久代用的是JVM的堆内存

通过-XX:+PrintGCDetails查看GC收集日志


image.png image.png image.png image.png image.png image.png

该参数范围只能设置0~15(java8)

引用

image.png

强引用

image.png

软引用

image.png

弱引用

image.png

软/弱引用使用场景

image.png

虚引用

image.png

GC Roots和四大引用总结

image.png

OOM(常见)

image.png image.png

GC Overhead

image.png

Direct buffer memory

image.png

通常因为NIO导致

unable to create new native thread

image.png

Metaspace

image.png

GC 收集器

image.png

其中,G1收集器是将堆内存分割成不同的区域然后并发的对其进行垃圾回收.

image.png

java8

image.png image.png

新生代收集器

image.png image.png image.png image.png image.png image.png

老年代收集器

image.png image.png

CMS4步过程


image.png

1.初始标记


image.png

2.并发标记

image.png

3.重新标记


image.png

4.并发清除

image.png

四步总结


image.png

CMS优缺点:
优:并发收集低停顿

缺:1.采用标记清除算法会导致大量内存碎片
2.并发执行对CPU压力大


image.png

缺点主要原因

如何选择垃圾收集器

image.png

G1收集器

image.png image.png image.png image.png

特点


image.png

G1底层原理

image.png image.png image.png image.png image.png

回收步骤


image.png image.png

四步


image.png

G1较与CMS的优势

image.png
上一篇 下一篇

猜你喜欢

热点阅读