美文网首页
简单学GC理论

简单学GC理论

作者: 白马王朗 | 来源:发表于2018-01-28 13:29 被阅读0次

对象存活算法

1.引用计数法:缺点是互相引用的对象无法识别,如:objA.field = objB;objB.field = objA。
2.可达性算法:GC Roots:虚拟机栈引用的对象、本地方法栈引用的对象、方法区静态属性引用的对象、方法区中常量引用的对象。

垃圾收集算法

1.标记清除(老年代,会产生内存碎片)
2.复制算法(年轻代,Eden to S0,S0 to S1)
3.标记整理(老年代,优化标记清除)
4.分代回收;

垃圾收集算法的实现:垃圾回收器

垃圾回收器

介绍垃圾回收器之前,先讲一下“并发”与“并行”的区别:
并发:用户线程与垃圾收集线程同时执行。
并行:多条垃圾回收线程并行工作,用户线程处于等待状态;
STW:stop the world,即暂停所有用户线程。

1.Serial收集器:适用于单CPU环境,一般用作client端(会发生“STW”)
2.ParNew收集器:采用复制算法,并发版本Serial收集器(会发生“STW”)
3.Parallel Scavenge:复制算法(会发生“STW”)
4.CMS垃圾回收器:采用标记清除算法,四个阶段:初始标记、并发标记、重新标记,并发清除。其中初始标记与重新标记需要“STW”。缺点:消耗cpu、产生碎片(设置fullgc时整理)。
5.Serial Old:单线程、标记整理。同样给Client端使用。
6.Parallel Old:标记整理。

垃圾回收器组合:

PS + PS Old:
吞吐量:垃圾回收时间 / 垃圾回收 + 用户线程时间。
该组合为吞吐量优先收集器,JDK7u4版本后默认。

ParNew + CMS:
JDK7高版本默认组合。

内存分配与回收策略

1.对象优先分配到Eden区。
2.大对象直接进入老年代:防止年轻代重复复制。
3.长期存活的对象进入老年代:S区中的年龄达到阈值放入老年代。
4.动态对象年龄判定:S区年龄相同对象超过一半,将直接晋升老年代。
5.晋升老年代时需要判定老年代是否足够存放,如不足触发full gc。

相关文章

  • 简单学GC理论

    对象存活算法 1.引用计数法:缺点是互相引用的对象无法识别,如:objA.field = objB;objB.fi...

  • 漫谈GC——小心递归中产生的内存溢出

    之前的文章中有系统的讲过GC相关的理论知识,如果对GC相关的理论知识不太理解的朋友,可以阅读一下:漫谈GC —— ...

  • 易CG | 零基础如何学动漫绘画

    经常有很多小伙伴问易GC,零基础如何学动漫?从来没有接触过绘画,所以不知道如何学动漫绘画,今天易GC就简单来分析一...

  • Java GC 理论

    本文聊聊Java 虚拟机的一些概念,常见GC算法底层过程,图解,并跟踪日志做分析。篇幅有点长,不要抱着一次看完的心...

  • GC原理及调优

    本文介绍 GC 基础原理和理论,GC 调优方法思路和方法,基于 Hotspot jdk1.8,学习之后你将了解如何...

  • jvm GC日志 相关参数

    -XX:+PrintGC 最简单的 GC 参数 会打印 GC 前后堆空间使用情况以及 GC 花费的时间 -XX:+...

  • 一文读懂Java GC原理和调优

    概述 本文介绍GC基础原理和理论,GC调优方法思路和方法,基于Hotspot jdk1.8,学习之后将了解如何对生...

  • 老大难的Java GC原理和调优,看这篇就够了

    概述 本文介绍GC基础原理和理论,GC调优方法思路和方法,基于Hotspot jdk1.8,学习之后将了解如何对生...

  • Go GC 简介

    简单了解 GC 与 mutator 线程并发运行,允许多个 GC 线程并行运行 在 GC 的过程中同时运行的 G ...

  • iOS - 老生常谈内存管理(一):引用计数

    简单聊聊 GC 与 RC 随着各个平台的发展,现在被广泛采用的内存管理机制主要有 GC 和 RC 两种。 GC (...

网友评论

      本文标题:简单学GC理论

      本文链接:https://www.haomeiwen.com/subject/pjuaaxtx.html