本系列会持续更新。java
金三已通过去一半了,即将进入面试的高峰期。在BAT面试中,JVM基本都是必考的系列。你至少须要掌握:JVM内存模型与JVM参数详细配置、JVM的4种垃圾回收算法、垃圾回收机制等(文末直达)程序员
以及今天重点谈到的JVM垃圾回收算法的实现:JVM垃圾收集器。面试
我先从JVM收集器的发展过程谈起,而后再聚焦在G1收集器,从G1的内存模型,再到G1的回收流程,最后再谈谈G1的实际应用场景。算法
JVM垃圾收集器发展历程多线程
第一阶段,Serial(串行)收集器架构
在jdk1.3.1以前,java虚拟机仅仅能使用Serial收集器。 Serial收集器是一个单线程的收集器,但它的“单线程”的意义并不只仅是说明它只会使用一个CPU或一条收集线程去完成垃圾收集工做,更重要的是在它进行垃圾收集时,必须暂停其余全部的工做线程,直到它收集结束。并发
第二阶段,Parallel(并行)收集器高并发
Parallel收集器也称吞吐量收集器,相比Serial收集器,Parallel最主要的优点在于使用多线程去完成垃圾清理工做,这样能够充分利用多核的特性,大幅下降gc时间。性能
第三阶段,CMS(并发)收集器spa
CMS收集器在Minor GC时会暂停全部的应用线程,并以多线程的方式进行垃圾回收。在Full GC时再也不暂停应用线程,而是使用若干个后台线程按期的对老年代空间进行扫描,及时回收其中再也不使用的对象。
第四阶段,G1(并发)收集器
G1收集器(或者垃圾优先收集器)的设计初衷是为了尽可能缩短处理超大堆(大于4GB)时产生的停顿。相对于CMS的优点而言是内存碎片的产生率大大下降。
JVM垃圾收集器
1.新生代
2.老年代
详细的垃圾收集器比较,具体能够查看往期文章:7种JVM垃圾收集器特色(文末直达)。
JDK1.7后全新的JVM垃圾收集器G1收集器, 目标用于取代CMS收集器。
G1收集器概述
从JDK(1.3)开始,HotSpot团队一直努力朝着高效收集、减小停顿(STW: Stop The World)的方向努力,也贡献了从串行Serial收集器、到并行收集器Parallerl收集器,再到CMS并发收集器,乃至现在的G1在内的一系列优秀的垃圾收集器。
G1(Garbage First)垃圾收集器是当今垃圾回收技术最前沿的成果之一。早在JDK7就已加入JVM的收集器你们庭中,成为HotSpot重点发展的垃圾回收技术。同优秀的CMS垃圾回收器同样,G1也是关注最小时延的垃圾回收器,也一样适合大尺寸堆内存的垃圾收集,官方也推荐使用G1来代替选择CMS。
2. G1相比较CMS的改进
3. CMS和G1的区别
4. G1收集器的应用场景
G1垃圾收集算法主要应用在多CPU大内存的服务中,在知足高吞吐量的同时,尽量的知足垃圾回收时的暂停时间。
就目前而言、CMS仍是默认首选的GC策略、可能在如下场景下G1更适合:
G1的堆内存算法
2. G1收集器的内存模型
1) G1堆内存结构
堆内存会被切分红为不少个固定大小区域(Region),每一个是连续范围的虚拟内存。
堆内存中一个区域(Region)的大小能够经过-XX:G1HeapRegionSize参数指定,大小区间最小1M、最大32M,总之是2的幂次方。
默认把堆内存按照2048份均分。
2) G1堆内存分配
每一个Region被标记了E、S、O和H,这些区域在逻辑上被映射为Eden,Survivor和老年代。
存活的对象从一个区域转移(即复制或移动)到另外一个区域。区域被设计为并行收集垃圾,可能会暂停全部应用线程。
如上图所示,区域能够分配到Eden,survivor和老年代。此外,还有第四种类型,被称为巨型区域(Humongous Region)。Humongous区域是为了那些存储超过50%标准region大小的对象而设计的,它用来专门存放巨型对象。若是一个H区装不下一个巨型对象,那么G1会寻找连续的H分区来存储。为了能找到连续的H区,有时候不得不启动Full GC。
G1回收流程
在执行垃圾收集时,G1以相似于CMS收集器的方式运行。
1)G1执行的第一阶段:初始标记(Initial Marking )
这个阶段是STW(Stop the World )的,全部应用线程会被暂停,标记出从GC Root开始直接可达的对象。
2)G1执行的第二阶段:并发标记
从GC Roots开始对堆中对象进行可达性分析,找出存活对象,耗时较长。当并发标记完成后,开始最终标记(Final Marking )阶段
3)最终标记
标记那些在并发标记阶段发生变化的对象,将被回收。
4)筛选回收
首先对各个Regin的回收价值和成本进行排序,根据用户所期待的GC停顿时间指定回收计划,回收一部分Region。
最后,G1中提供了两种模式垃圾回收模式,Young GC和Mixed GC,两种都是Stop The World(STW)的。
G1的GC模式
在分配通常对象(非巨型对象)时,当全部eden region使用达到最大阀值而且没法申请足够内存时,会触发一次YoungGC。每次younggc会回收全部Eden以及Survivor区,而且将存活对象复制到Old区以及另外一部分的Survivor区。
YoungGC的回收过程以下:
2. mixed gc
当愈来愈多的对象晋升到老年代old region时,为了不堆内存被耗尽,虚拟机会触发一个混合的垃圾收集器,即mixed gc,该算法并非一个old gc,除了回收整个young region,还会回收一部分的old region,这里须要注意:是一部分老年代,而不是所有老年代,能够选择哪些old region进行收集,从而能够对垃圾回收的耗时时间进行控制。
G1没有fullGC概念,须要fullGC时,调用serialOldGC进行全堆扫描(包括eden、survivor、o、perm)。
G1的推荐用例
G1的第一个重要特色是为用户的应用程序的提供一个低GC延时和大内存GC的解决方案。这意味着堆大小6GB或更大,稳定和可预测的暂停时间将低于0.5秒。
若是应用程序使用CMS或ParallelOld垃圾回收器具备一个或多个如下特征,将有利于切换到G1:
注意:若是你正在使用CMS或ParallelOld收集器,而且你的应用程序没有遇到长时间的垃圾收集暂停,则保持与您的当前收集器是很好的,升级JDK并没必要要更新收集器为G1。
以为不错请点赞支持下。
----end----
如下是JVM系列文章集合,感兴趣不妨深刻了解,扩充知识栈:
JVM的4种垃圾回收算法、垃圾回收机制与总结
7种JVM垃圾收集器特色,优劣势、及使用场景
深刻详解JVM内存模型与JVM参数详细配置
JVM性能调优的6大步骤,及关键调优参数详解
做者Mike,10年+程序员。主要分享:BAT 面试、Java 架构、招聘资讯等内容。
曾前后就任于淘宝、盛大、百度、携程 ,历任高级研发工程师、研发经理、架构师、事业部 CTO。
坚持写文2年多,原创内容400篇,目前粉丝总数7万+,欢迎留言或进个人我的群179961551交流技术、分享面试机会,拒绝广告,我也会在群内不按期交流、探讨~