1 GC算法简介

算法 特点
标记-清除 分为“标记”和“清除”两个阶段
复制 可以解决效率问题,将可用的内存按容量划分为大小相等的两块。
标记-整理 先标记、再整理,最后清理
分代收集 划分新生代和老年代

2 标记-清除

2.1 流程

分为“标记”和“清除”两个阶段:
(1)首先标记出所需要回收的对象(引用计数法和可达性分析,两次标记过程);
(2)在标记完成后统一回收所有被标记的对象。

2.2 缺点

(1)效率问题:标记和清除两个过程的效率不高;
(2)空间问题:标记清除后会产生大量不连续的内存碎片,导致以后在程序运行过程中需要分配较大对象时,无法找到足够的连续内存而不得不提前触发另一次垃圾收集动作。

3 复制

3.1 流程

可以解决效率问题,将可用的内存按容量划分为大小相等的两块
(1)每次只使用其中的一块;
(2)当这一块用完了,就将还存活的对象复制到另一块上;
(3)然后再把已使用的内存空间清理掉。

3.2 优点

  每次对整个半区进行内存回收,避免内存碎片问题,只需移动堆顶指针,按顺序分配内存即可,实现简单,运行高效。

3.3 缺点

  将内存缩小为原来的一半,代价高;当对象存活率较高时需要进行较多的复制操作,效率降低。

3.4 应用

  回收新生代,新生代中分为Eden空间和两块较小的Survivor空间,每次使用Eden和其中的一块Survivor。默认Eden:Survivor=8:1,Survivor不够时,老年代内存分配担保。

4 标记-整理

4.1 流程

(1)首先标记处所需要回收的对象;
(2)不直接对可回收对象进行清理,让所有存活的对象都向一端移动
(3)直接清理掉端边界以外的内存。

4.2 优点

  改进了复制算法在对象存活率较高时带来的效率问题;

4.3 应用

  老年代收集(对象存活率较高)

5 分代收集

5.1 思想

  根据对象存活周期的不同将内存划分为新生代和老年代,根据各自的特点采用合适的收集算法。
(1)新生代中,每次垃圾收集时都发现有大批对象死去,少量存活,选用复制算法;
(2)老年代中,对象存活率高、没有额外空间进行分配担保,使用“标记-清理”或者“标记-整理”。

6 QA

6.1 为什么不是1块Survivor空间而是2块?

  这里涉及到一个新生代和老年代的存活周期的问题,比如一个对象在新生代经历15次GC回收,就可以移到老年代了。问题来了,当我们第一次GC的时候,我们可以把Eden区的存活对象放到Survivor-1空间,但是第二次GC的时候,Survivor-1空间和Eden区的存活对象也需要再次用复制算法,放到Survivor-2空间上,而把刚刚的Survivor-1空间和Eden空间清除。第三次GC时,又把Survivor-2空间和Eden区的存活对象复制到Survivor-1空间,如此反复。
  所以,这里就需要2块Survivor空间来回倒腾。

6.2 为什么Eden空间这么大而Survivor空间要分的少一点?

  1. 新创建的对象都是放在Eden空间,这是很频繁的,尤其是大量的局部变量产生的临时对象,这些对象绝大部分都应该马上被回收,能存活下来被转移到survivor空间一般不是很多。所以,设置较大的Eden空间和较小的Survivor空间是合理的,大大提高了内存的使用率,缓解了复制算法的缺点。
  2. 8:1:1这种比例就挺好的,当然这个比例是可以调整的,包括上面的新生代和老年代的1:2的比例也是可以调整的。
  3. 新的问题又来了,从Eden空间往Survivor空间转移的时候,如果出现Survivor空间不够了怎么办?直接放到老年代去。 有的对象来回在Survivor-1区或者Survivor-2区呆了比如15次,就被分配到老年代Old区;有的对象太大,超过了Eden区,直接被分配在Old区;有的存活对象,放不下Survivor区,也被分配到Old区。如果老年代Old区也被放满了,就是一次大GC即为Major GC。

JVM—垃圾回收GC算法相关推荐

  1. 垃圾回收机制和JVM垃圾回收常见算法

    垃圾回收机制和JVM垃圾回收常见算法 垃圾回收的好处和特点: 好处: 1. 提高编程效率: 2. 垃圾回收机制保护程序的完整性. 特点: 1. 只能回收无用对象的内存空间,对其他物理资源无能为力: 2 ...

  2. jvm - 垃圾回收 gc

    2019独角兽企业重金招聘Python工程师标准>>> jvm - 垃圾回收 注意 : 本系列文章为学习系列,部分内容会取自相关书籍或者网络资源,在文章中间和末尾处会有标注 垃圾回收 ...

  3. JVM垃圾回收与算法(2)

    垃圾回收与算法 2.1如何确定垃圾 在接触垃圾回收机制和算术法之前,先了解下引用计数法的概念和可达性分析,是对理解垃圾回收算法的基础. 2.1.1:引用计数法的概念 在java中,引用和对象是关联的, ...

  4. JVM—垃圾回收与算法

    目录 一.如何确定垃圾 1.引用计数法 2.可达性分析 二.标记清除算法(Mark-Sweep) 三.复制算法(copying) 四.标记整理算法(Mark-Compact) 五.分代收集算法 1.新 ...

  5. JVM - 垃圾回收相关算法

    目录 总览 垃圾标记阶段:对象存活判断 引用计数算法 可达性分析算法(根搜索算法.追踪性垃圾收集) 对象的 finalization 机制 MAT 与 JProfiler 查看 GC Roots 垃圾 ...

  6. java 虚拟机 Java内存结构 JVM垃圾回收机制算法

    什么是HotSpot VM 提起HotSpot VM,相信所有Java程序员都知道,它是Sun JDK和OpenJDK中所带的虚拟机,也是目前使用范围最广的Java虚拟机. 但不一定所有人都知道的是, ...

  7. JVM垃圾回收(GC)

    如何识别垃圾 垃圾回收主要方法 分代收集算法 垃圾收集器 JVM参数 测试 如何识别垃圾 引用计数法 对象被引用一次,在它的对象头上加一次引用次数,如果没有被引用(引用次数为 0),则此对象可回收 代 ...

  8. JVM垃圾回收算法 总结及汇总

    先看一眼JVM虚拟机运行时的内存模型: 1.方法区 Perm(永久代.非堆) 2.虚拟机栈 3.本地方法栈 (Native方法) 4.堆 5.程序计数器 1 首先的问题是:jvm如何知道那些对象需要回 ...

  9. JVM 垃圾回收算法 -可达性分析算法!!!高频面试!!!

    前言:学习JVM,那么不可避免的要去了解JVM相关的垃圾回收算法,本文只是讲了讲了可达性分析算法,至于标记-清除.标记-复制,标记-整理,分代收集等等算法,会在近两天的文章中陆续更新出来. 很喜欢一句 ...

最新文章

  1. 第六阶段 小学期(一)——电子商务
  2. 并发测试mysql_Jmeter性能测试系列——结果分析与报告输出
  3. 周一02.1编程语言介绍
  4. Service Cloud: Quick Look
  5. C++内存分配方式详解——堆、栈、自由存储区、全局/静态存储区和常量存储区
  6. 分享2018年陆陆续续读过的书-附书单
  7. ef 数据迁移mysql_07116.3.0如何将CM的外部PostgreSQL数据库迁移至MySQL服务
  8. 实战:网店活动付邮试用全攻略
  9. WebBrowser控件禁用超链接转向、脚本错误提示、默认右键菜单和快捷键
  10. android布局的属性,android
  11. CANN5.0黑科技解密 | 高并发图片视频处理,为出行保驾,为生活添彩
  12. idea打开vue项目后报错ESLint: Expected space or tab after ‘//‘ in comment.(spaced-comment)
  13. 两周内股指见底概率大
  14. python raw input用法_如何在 python raw_input 中使用 tab 键补全?
  15. php中文件读写总结,PHP读取文件_2014.5.26的总结
  16. 以读者角度走进RFID打造的智慧图书馆
  17. kaldi 学习笔记-三音素训练1(Decision Tree)
  18. RPA应用场景-交通违章查询
  19. chmod 777 什么意思:鸟哥的linux私房菜第六章学习笔记
  20. SQL SERVER 2019卸载和安装

热门文章

  1. Python:pyinstaller报错【A RecursionError maximum recursion depth exceeded occurred】
  2. bcb6通过https接口post数据_Python+Requests+Pytest+YAML+Allure实现接口自动化
  3. Mybatis(16)注解开发环境搭建
  4. localStorage、sessionStorage本地存取Object 对象 - 代码篇
  5. 电影网址导航V20201218版源码
  6. android数据返回,android提交数据后,得到的返回值为一个对象该怎么写?
  7. 简单干净的Emlog6.0.1技术导航模板源码-视频教程
  8. Linux写出相应密码的用途,linux运维面试题中级
  9. 电脑设置代理IP工具 可自动更新
  10. 分享一款自用网站导航分类目录程序源码