一、垃圾回收算法

1、标记—清除算法

1)工作流程

算法分为“标记”和“清除”阶段:首先标记出所有需要回收的对象(标记阶段),在标记完成后统一回收所有被标记的对象(回收阶段)。

2)缺点

a. 效率问题:标记和清除这两个过程的效率都不高。

b. 空间问题:会产生大量的不连续碎片。

2、复制算法(新生代垃圾回收算法)

1)工作流程

将内存划分为大小相等的两块,每块只使用其中的一块,另外一块作为保留区域,当进行垃圾回收时,将使用区域的存活对象一次性进行赋值到保留区域,而后一次性清空使用区域。

2)使用场景

新生代垃圾回收,新生代对象具有朝生夕灭的特性(新生代对象存活率低)。

3)优点:实现简单,运行效率高,无空间碎片问题。

4)JVM采用的复制算法:

将内存划分(新生代内存)为一块较大的Eden区域和两块大小相等、空间较小的Survivor区域(Eden:Survivor = 8:1)。

每次使用Eden和其中的一块Survivor区域(第一块Survivor区域为from区域,另外一块为to区域)。

在进行垃圾回收时(Eden区域快满时,系统自动触发垃圾回收)

A. 第一次进行GC时,将Eden区中的对象移动到from区域。

B. 第二次再进行GC时,将Eden区和from区中存活的对象移动到to区域,然后一次性清除掉Eden和from区,以此循环。

C. 对象在from区域和to区域来回移动15次(默认),将对象移动到老年代。

D. 特殊情况:当Survivor区域放不下存活对象时,会从老年代进行分配担保。

3、标记整理算法(老年代回收算法)

复制算法在对象存活率比较高的情况下,会有大量对象复制操作,效率很低,因此,老年代不采用复制算法。

1)工作流程:

标记阶段和标记清除阶段的标记类似,标记出无用对象。

整理阶段:将存活对象向一端移动,而后一次性将存活对象边界以外的空间清除掉。

4、分代回收算法

Java采用分代回收算法,即新生代采用复制算法,而老年代采用标记整理算法。

将内存划分为新生代(对象存活率低)和老年代(对象存活率高)。

面试考点:请问了解Minor GC和Major GC吗?

Minor GC:新生代GC,指的是新生代垃圾回收,在新生代中,对象大多数朝生夕灭,因此采用复制算法,Major GC发生频繁,效率较高,

Major GC (老年代GC/Full GC):指的是发生在老年代的垃圾回收,发生Full GC通常会至少发生一次Minor GC,但并非绝对,Full GC 速度比Minor G从速度慢10倍以上,发生频率较低。

二、垃圾回收器

并行:指的是多条垃圾回收线程并行工作,而用户线程等待。

并发:用户线程与垃圾回收线程同时执行(不一定并行,可能交替执行),用户线程继续执行,垃圾回收线程运行在另外的内核中。

吞吐量:CPU运行用户代码时间/CPU总时间

CPU总时间即用户代码时间+垃圾回收时间

新生代垃圾回收器:Serial、ParNew、Parallel scavenge

老年代垃圾回收器:SeralOld、ParallelOld、CMS

全区域垃圾回收器:G1

1、Serial收集器(新生代垃圾回收,串行收集器)

(1)特性:Serial是一个单线程收集器,在Serial进行垃圾收集时,必须暂停其他所有的工作线程,直到Serial收集器手机结束(STW)。

(2)应用场景:Serial收集器是JVM运行在Client模式下默认的新生代收集器。

(3)优点:简单而高效,对于单核CPU,Serial收集器由于没有线程交互开销,可以获得最高的单线程收集效率。

2、ParNew收集器(新生代收集器,并行GC)

(1)特性:ParNew收集器是Serial收集器的多线程版本。

(2)应用场景:PerNew是许多运行在Serial模式下的JVM首选新生代收集器。

(3)优点:随着可使用CPU数量的增加,对于GC时系统资源的利用有较大帮助。

3、Parallel Scavenge 收集器(吞吐量有限收集器,新生代收集器,并行GC)

(1)特性:吞吐量

两个参数控制吞吐量:

a. .-xx:MaxGCPauseMillis:控制最大垃圾收集器停顿时间。

b. .-xx:GCRatio:直接设置吞吐量大小

(2)应用场景:高吞吐量场景,适合需要与用户交互的程序(B/S架构),良好的响应速度提升用户体验。

(3)优点:与ParNew收集器比较:高吞吐量。

GC自调节策略(-xx:+UseAdaptiveSizePolicy)

4、Serial Old收集器(老年代收集器,并行GC)

(1)特性:Serial Old是Serial老年代版本,单线程收集器,实用标记整理算法。

(2)应用场景:

1)Client模式下:Serial Old主要也在于给Client模式下的虚拟机使用。

2)Server模式下:作为CMS收集器的后备预案,当CMS发生并发失败问题时使用。

5、Parallel Old收集器(老年代收集器,并行GC)

(1)特性:Parallel Old是Parallel Scavenge老年代版本。

(2)应用场景:注重吞吐量以及CPU资源敏感场合。

6、CMS(老年代垃圾收集器,并行GC):采用标记清除算法

(1)特性:CMS收集器是以获得最短系统停顿时间为目标的垃圾回收器。

(2)应用场景:B/S系统:服务端。B/S系统重视服务器的响应速度,希望系统停顿时间尽可能短,CMS收集器非常符合此类应用需求。

(3)优点:并发收集,低停顿。

(4)缺点:对CPU资源敏感,产生大量空间碎片。

7、G1(全区域垃圾回收器)

应用场景:应用于低停顿场景。

JVM——垃圾收集算法及垃圾回收器的更多相关文章

  1. JVM 垃圾回收算法和垃圾回收器

    JVM 垃圾回收算法和垃圾回收器. 一.垃圾回收的区域 栈:栈中的生命周期是跟随线程,所以一般不需要关注. 堆:堆中的对象是垃圾回收的重点. 方法区:这一块也会发生垃圾回收,不过这块的效率比较低,一般 ...

  2. JVM 垃圾收集算法 标记-清楚、标记-复制、标记-整理

    摘要 Java程序在运行过程中会产生大量的对象,但是内存大小是有限的,如果光用而不释放,那内存迟早被耗尽.如C.C++程序,需要程序员手动释放内存,Java则不需要,是由垃圾回收器去自动回收. 垃圾回 ...

  3. JVM垃圾收集算法(标记-清除、复制、标记-整理)

     [JVM垃圾收集算法] 1)标记-清除算法: 标记阶段:先通过根节点,标记所有从根节点开始的对象,未被标记的为垃圾对象(错了吧?) 清除阶段:清除所有未被标记的对象 2)复制算法: 将原有的内存空间 ...

  4. 深入理解JVM(五)——垃圾回收器

    轻松学习JVM(五)——垃圾回收器 上一篇我们介绍了常见的垃圾回收算法,不同的算法各有各的优缺点,在JVM中并不是单纯的使用某一种算法进行垃圾回收,而是将不同的垃圾回收算法包装在不同的垃圾回收器当中, ...

  5. JVM的垃圾回收机制 总结(垃圾收集、回收算法、垃圾回收器)

     相信和小编一样的程序猿们在日常工作或面试当中经常会遇到JVM的垃圾回收问题,有没有在夜深人静的时候详细捋一捋JVM垃圾回收机制中的知识点呢?没时间捋也没关系,因为小编接下来会给你捋一捋. 一. 技术 ...

  6. java架构之路-(12)JVM垃圾回收算法和垃圾回收器

    接上次JVM虚拟机堆内存模型来继续说,上次我们主要说了什么时候可能把对象直接放在老年代,还有我们的可能性分析,提出GCroot根的概念.这次我们主要来说说垃圾回收所使用的的算法和我们的垃圾回收器,需要 ...

  7. Jvm垃圾收集器和垃圾回收算法

    概述: 目前内存的动态分配和内存的回收技术已经相当成熟,一切看起来都已经进入了“自动化”时代,为什么还要去了解GC和内存分配呢?原因很简单:当需要排查各种内存泄漏.内存溢出问题时,当垃圾收集器成为系统 ...

  8. Java垃圾回收算法和垃圾回收器

    基本上 jvm内存回收有三种 基本算法 标记-清除 标记清除的算法最简单,主要是标记出来需要回收的对象,然后然后把这些对象在内存的信息清除.如何标记需要回收的对象,在上一篇文章里面已经有说明. 标记- ...

  9. [JVM 相关] Java 新型垃圾回收器(Garbage First,G1)

    回顾传统垃圾回收器 HotSpot 垃圾收集器实现 Serial Collector(串型收集器) 使用场景,大多数服务器是单核CPU. 适用收集场景:1. 新生代收集(Young Generatio ...

随机推荐

  1. 源码安装的应用 rpm 命令无法查询

    源码安装:一大堆源码文件,需要编译后才能使用(编译需要安装编译器 :yum install gcc) rpm 安装:redhat 官网或其它开源网站编译好发布,已经编译好的安装包,使用 rpm -iv ...

  2. (转)刚来的大神彻底干掉了代码中的if else...

    一旦代码中 if-else 过多,就会大大的影响其可读性和可维护性. 首先可读性,不言而喻,过多的 if-else 代码和嵌套,会使阅读代码的人很难理解到底是什么意思.尤其是那些没有注释的代码. 其次 ...

  3. Go语言核心36讲(Go语言进阶技术十四)--学习笔记

    20 | 错误处理 (下) 在上一篇文章中,我们主要讨论的是从使用者的角度看"怎样处理好错误值".那么,接下来我们需要关注的,就是站在建造者的角度,去关心"怎样才能给予使 ...

  4. jmeter 数据库压力测试之MySql

    1.首先下载合适的数据库驱动:https://mvnrepository.com/artifact/mysql/mysql-connector-java 2.创建testplan,并添加jar包 3. ...

  5. LeetCode 199. 二叉树的右视图 C++ 用时超100%

    /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode ...

  6. 【GIS】GeoServer服务Authkey配置记录

    特别感谢:https://www.cnblogs.com/HandyLi/p/8624507.html 1.服务受控配置 2.授权方式 3.Url模式配置 4.Authkey密钥配置 5.使用 在wm ...

  7. CentOS7 hadoop3.3.1安装(单机分布式、伪分布式、分布式)

    @ 目录 前言 预先设置 修改主机名 关闭防火墙 创建hadoop用户 SSH安装免密登陆 单机免密登陆--linux配置ssh免密登录 linux环境配置Java变量 配置Java环境变量 安装Ha ...

  8. 使用Token进行CSRF漏洞防御

    1.登录验证成功之后,在会话SESSION["user_token"]中保存Token. 2.在后台操作中,增删改表单中添加隐藏域hidden,设置value为Token. 3.提 ...

  9. ECharts 点击事件

    一个问题 ECharts 点击出现多个弹窗

  10. 菜鸡的Java笔记 第二十四 - java 接口的基本定义

    1.接口的基本定义以及使用形式        2.与接口有关的设计模式的初步认识        3.接口与抽象类的区别                 接口与抽象类相比,接口的使用几率是最高的,所有的 ...