美文网首页
JVM.003.垃圾回收器

JVM.003.垃圾回收器

作者: InitialX | 来源:发表于2019-02-27 10:19 被阅读0次

阅读原文:https://blog.csdn.net/singc/article/details/108646348

1 JVM内存模型

谈到垃圾回收,我们先回顾下JVM的内存组成:

线程隔离性 内存类型 用途
线程隔离 1.本地方法栈 存储JVM的native方法
2.虚拟机栈 存储类方法里的局部变量、返回结果链接、程序执行的字节位置等,其生命周期与线程一致
3.程序计数器 根据虚拟机栈中存储的字节位置,在线程切换后找到上次执行位置。
线程共享 1.堆 存储对象实例和数组
2.方法区(永久代) 存储类加载文件、常量、静态变量等。在Java8中永久代被移除,由“元数据区”取代
直接内存 NIO等 在JDK1.4时引入了NIO,可以不通JVM而由Native方法直接在系统内存进行IO操作,显著提升了效率
在这里插入图片描述

垃圾回收主要是针对堆内存进行!

2 垃圾回收与算法

2.1 回收对象

垃圾回收对象通常是指已死亡的变量。常用的确认算法有2种:

  • 引用计数法
  • 可达性分析法

2.2 回收算法

  • 标记算法
  • 复制算法
  • 标记-整理算法

垃圾回收器按照其算法特性不同,其在各分代中的使用也不同。

  • 新生代(young generation)有三种GC:
    -Serial(串行) : 只会使用1个cpu或线程进行垃圾回收,而且回收过程中,其他所有线程都必须暂停,直至回收结束,被戏称为“stop the world”。
    应用场景:用户端,由于是单线程运作,没有线程交互的大开销,故而效率很高,回收时间可以控制在毫秒级别,对于用户而言几乎没有停顿感。
    -ParNew
    Paralle Scavenge(scavenge:打扫)

  • 老年代(teunred generation)也有三种GC:
    CMS(Concurrent Mark Sweep)
    Serial Old(MSC)
    Paralle Old

  • 另外还有一个GC在新生代和老年代都会用到—— G1。

from 《深入理解Java虚拟机》

如图所示共有7种GC,如果有连线则表示二者可以搭配使用。

未完待续...

相关文章

网友评论

      本文标题:JVM.003.垃圾回收器

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